feat(web): memory insight
This commit is contained in:
@@ -1090,7 +1090,11 @@ export const en = {
|
|||||||
memoryContent: 'Memory Content',
|
memoryContent: 'Memory Content',
|
||||||
created_at: 'Created At',
|
created_at: 'Created At',
|
||||||
|
|
||||||
memoryWindow: "{{name}}'s Window of Memory"
|
memoryWindow: "{{name}}'s Window of Memory",
|
||||||
|
memory_insight: 'Overall Overview',
|
||||||
|
key_findings: 'Key Findings',
|
||||||
|
behavior_pattern: 'Behavior Pattern',
|
||||||
|
growth_trajectory: 'Growth Trajectory',
|
||||||
},
|
},
|
||||||
space: {
|
space: {
|
||||||
createSpace: 'Create Space',
|
createSpace: 'Create Space',
|
||||||
|
|||||||
@@ -1172,7 +1172,11 @@ export const zh = {
|
|||||||
updated_at: '最后更新时间',
|
updated_at: '最后更新时间',
|
||||||
fullScreen: '全屏',
|
fullScreen: '全屏',
|
||||||
|
|
||||||
memoryWindow: "{{name}}的记忆之窗"
|
memoryWindow: "{{name}}的记忆之窗",
|
||||||
|
memory_insight: '总体概述',
|
||||||
|
key_findings: '关键发现',
|
||||||
|
behavior_pattern: '行为模式',
|
||||||
|
growth_trajectory: '成长轨迹',
|
||||||
},
|
},
|
||||||
space: {
|
space: {
|
||||||
createSpace: '创建空间',
|
createSpace: '创建空间',
|
||||||
@@ -1657,6 +1661,8 @@ export const zh = {
|
|||||||
'question-classifier': '问题分类器',
|
'question-classifier': '问题分类器',
|
||||||
iteration: '迭代 (Iteration)',
|
iteration: '迭代 (Iteration)',
|
||||||
loop: '循环 (Loop)',
|
loop: '循环 (Loop)',
|
||||||
|
'cycle-start': '',
|
||||||
|
'cycle-end': '退出循环',
|
||||||
parallel: '并行执行',
|
parallel: '并行执行',
|
||||||
'var-aggregator': '变量聚合器',
|
'var-aggregator': '变量聚合器',
|
||||||
externalInteraction: '外部交互',
|
externalInteraction: '外部交互',
|
||||||
@@ -1802,9 +1808,14 @@ export const zh = {
|
|||||||
class_name: '分类',
|
class_name: '分类',
|
||||||
addClassName: '添加分类'
|
addClassName: '添加分类'
|
||||||
},
|
},
|
||||||
|
loop: {
|
||||||
|
cycle_vars: '循环变量',
|
||||||
|
condition: '循环终止条件',
|
||||||
|
},
|
||||||
name: '键',
|
name: '键',
|
||||||
type: '类型',
|
type: '类型',
|
||||||
value: '值',
|
value: '值',
|
||||||
|
addCase: '添加条件',
|
||||||
},
|
},
|
||||||
|
|
||||||
clear: '清空',
|
clear: '清空',
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
import { type FC, useEffect, useState, forwardRef, useImperativeHandle } from 'react'
|
import { useEffect, useState, forwardRef, useImperativeHandle } from 'react'
|
||||||
|
import clsx from 'clsx'
|
||||||
import { useTranslation } from 'react-i18next'
|
import { useTranslation } from 'react-i18next'
|
||||||
import { useParams } from 'react-router-dom'
|
import { useParams } from 'react-router-dom'
|
||||||
import { Skeleton } from 'antd';
|
import { Skeleton, Space } from 'antd';
|
||||||
import RbCard from '@/components/RbCard/Card'
|
import RbCard from '@/components/RbCard/Card'
|
||||||
import Empty from '@/components/Empty';
|
import Empty from '@/components/Empty';
|
||||||
import {
|
import {
|
||||||
@@ -9,11 +10,20 @@ import {
|
|||||||
} from '@/api/memory'
|
} from '@/api/memory'
|
||||||
import type { MemoryInsightRef } from '../types'
|
import type { MemoryInsightRef } from '../types'
|
||||||
|
|
||||||
|
interface Data {
|
||||||
|
memory_insight?: string;
|
||||||
|
behavior_pattern?: string;
|
||||||
|
key_findings?: string[];
|
||||||
|
growth_trajectory?: string;
|
||||||
|
updated_at?: number;
|
||||||
|
is_cached: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
const MemoryInsight = forwardRef<MemoryInsightRef>((_props, ref) => {
|
const MemoryInsight = forwardRef<MemoryInsightRef>((_props, ref) => {
|
||||||
const { t } = useTranslation()
|
const { t } = useTranslation()
|
||||||
const { id } = useParams()
|
const { id } = useParams()
|
||||||
const [loading, setLoading] = useState<boolean>(false)
|
const [loading, setLoading] = useState<boolean>(false)
|
||||||
const [report, setReport] = useState<string | null>(null)
|
const [data, setData] = useState<Data>({} as Data)
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!id) return
|
if (!id) return
|
||||||
@@ -25,7 +35,7 @@ const MemoryInsight = forwardRef<MemoryInsightRef>((_props, ref) => {
|
|||||||
if (!id) return
|
if (!id) return
|
||||||
setLoading(true)
|
setLoading(true)
|
||||||
getMemoryInsightReport(id).then((res) => {
|
getMemoryInsightReport(id).then((res) => {
|
||||||
setReport((res as { report?: string }).report || null)
|
setData((res as Data) || {})
|
||||||
setLoading(false)
|
setLoading(false)
|
||||||
})
|
})
|
||||||
.finally(() => {
|
.finally(() => {
|
||||||
@@ -43,10 +53,35 @@ const MemoryInsight = forwardRef<MemoryInsightRef>((_props, ref) => {
|
|||||||
>
|
>
|
||||||
{loading
|
{loading
|
||||||
? <Skeleton />
|
? <Skeleton />
|
||||||
: report
|
: Object.keys(data).length > 0
|
||||||
? <div className="rb:bg-[#F6F8FC] rb:border rb:border-[#DFE4ED] rb:rounded-lg rb:py-3 rb:px-4 rb:text-[#5B6167] rb:leading-5">
|
? <Space size={16} direction="vertical" className="rb:w-full">
|
||||||
{report || '-'}
|
{['memory_insight', 'key_findings', 'behavior_pattern', 'growth_trajectory'].map(key => {
|
||||||
</div>
|
if (data[key as keyof Data]) {
|
||||||
|
return (
|
||||||
|
<div key={key} className="rb:bg-[#F6F8FC] rb:border rb:border-[#DFE4ED] rb:rounded-lg rb:py-3 rb:text-[#5B6167] rb:leading-5">
|
||||||
|
<div className={clsx(`rb:relative rb:before:content-[''] rb:before:block rb:before:h-4 rb:before:absolute rb:before:top-0.5 rb:before:left-0 rb:before:w-1 rb:pl-4 rb:mb-2 rb:font-medium rb:leading-5`, {
|
||||||
|
'rb:before:bg-[#155EEF]': key === 'memory_insight',
|
||||||
|
'rb:before:bg-[#369F21]': key !== 'memory_insight'
|
||||||
|
})}>{t(`userMemory.${key}`)}</div>
|
||||||
|
<div className="rb:px-4">
|
||||||
|
{Array.isArray(data[key as keyof Data])
|
||||||
|
? <>
|
||||||
|
{(data[key as keyof Data] as string[])?.map((item: string, index: number) => (
|
||||||
|
<div key={index}>
|
||||||
|
- {item}
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</>
|
||||||
|
: data[key as keyof Data] as string
|
||||||
|
}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
return null
|
||||||
|
})}
|
||||||
|
|
||||||
|
</Space>
|
||||||
: <Empty size={80} />
|
: <Empty size={80} />
|
||||||
}
|
}
|
||||||
</RbCard>
|
</RbCard>
|
||||||
|
|||||||
Reference in New Issue
Block a user