
Signed-off-by: yihong0618 <zouzou0208@gmail.com> Signed-off-by: -LAN- <laipz8200@outlook.com> Co-authored-by: kurokobo <kuro664@gmail.com> Co-authored-by: Hiroshi Fujita <fujita-h@users.noreply.github.com> Co-authored-by: NFish <douxc512@gmail.com> Co-authored-by: Gen Sato <52241300+halogen22@users.noreply.github.com> Co-authored-by: eux <euxuuu@gmail.com> Co-authored-by: huangzhuo1949 <167434202+huangzhuo1949@users.noreply.github.com> Co-authored-by: huangzhuo <huangzhuo1@xiaomi.com> Co-authored-by: lotsik <lotsik@mail.ru> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: Wu Tianwei <30284043+WTW0313@users.noreply.github.com> Co-authored-by: nite-knite <nkCoding@gmail.com> Co-authored-by: Jyong <76649700+JohnJyong@users.noreply.github.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: gakkiyomi <gakkiyomi@aliyun.com> Co-authored-by: CN-P5 <heibai2006@gmail.com> Co-authored-by: CN-P5 <heibai2006@qq.com> Co-authored-by: Chuehnone <1897025+chuehnone@users.noreply.github.com> Co-authored-by: yihong <zouzou0208@gmail.com> Co-authored-by: Kevin9703 <51311316+Kevin9703@users.noreply.github.com> Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: Boris Feld <lothiraldan@gmail.com> Co-authored-by: mbo <himabo@gmail.com> Co-authored-by: mabo <mabo@aeyes.ai> Co-authored-by: Warren Chen <warren.chen830@gmail.com> Co-authored-by: KVOJJJin <jzongcode@gmail.com> Co-authored-by: JzoNgKVO <27049666+JzoNgKVO@users.noreply.github.com> Co-authored-by: jiandanfeng <chenjh3@wangsu.com> Co-authored-by: zhu-an <70234959+xhdd123321@users.noreply.github.com> Co-authored-by: zhaoqingyu.1075 <zhaoqingyu.1075@bytedance.com> Co-authored-by: 海狸大師 <86974027+yenslife@users.noreply.github.com> Co-authored-by: Xu Song <xusong.vip@gmail.com> Co-authored-by: rayshaw001 <396301947@163.com> Co-authored-by: Ding Jiatong <dingjiatong@gmail.com> Co-authored-by: Bowen Liang <liangbowen@gf.com.cn> Co-authored-by: JasonVV <jasonwangiii@outlook.com> Co-authored-by: le0zh <newlight@qq.com> Co-authored-by: zhuxinliang <zhuxinliang@didiglobal.com> Co-authored-by: k-zaku <zaku99@outlook.jp> Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: luckylhb90 <luckylhb90@gmail.com> Co-authored-by: hobo.l <hobo.l@binance.com> Co-authored-by: jiangbo721 <365065261@qq.com> Co-authored-by: 刘江波 <jiangbo721@163.com> Co-authored-by: Shun Miyazawa <34241526+miya@users.noreply.github.com> Co-authored-by: EricPan <30651140+Egfly@users.noreply.github.com> Co-authored-by: crazywoola <427733928@qq.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: sino <sino2322@gmail.com> Co-authored-by: Jhvcc <37662342+Jhvcc@users.noreply.github.com> Co-authored-by: lowell <lowell.hu@zkteco.in>
131 lines
3.7 KiB
TypeScript
131 lines
3.7 KiB
TypeScript
import {
|
|
memo,
|
|
useCallback,
|
|
useRef,
|
|
} from 'react'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { useClickAway } from 'ahooks'
|
|
import type { NodeProps } from 'reactflow'
|
|
import NodeResizer from '../nodes/_base/components/node-resizer'
|
|
import {
|
|
useNodeDataUpdate,
|
|
useNodesInteractions,
|
|
} from '../hooks'
|
|
import { useStore } from '../store'
|
|
import {
|
|
NoteEditor,
|
|
NoteEditorContextProvider,
|
|
NoteEditorToolbar,
|
|
} from './note-editor'
|
|
import { THEME_MAP } from './constants'
|
|
import { useNote } from './hooks'
|
|
import type { NoteNodeType } from './types'
|
|
import cn from '@/utils/classnames'
|
|
|
|
const Icon = () => {
|
|
return (
|
|
<svg xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 18 18" fill="none">
|
|
<path fillRule="evenodd" clipRule="evenodd" d="M12 9.75V6H13.5V9.75C13.5 11.8211 11.8211 13.5 9.75 13.5H6V12H9.75C10.9926 12 12 10.9926 12 9.75Z" fill="black" fillOpacity="0.16" />
|
|
</svg>
|
|
)
|
|
}
|
|
|
|
const NoteNode = ({
|
|
id,
|
|
data,
|
|
}: NodeProps<NoteNodeType>) => {
|
|
const { t } = useTranslation()
|
|
const controlPromptEditorRerenderKey = useStore(s => s.controlPromptEditorRerenderKey)
|
|
const ref = useRef<HTMLDivElement | null>(null)
|
|
const theme = data.theme
|
|
const {
|
|
handleThemeChange,
|
|
handleEditorChange,
|
|
handleShowAuthorChange,
|
|
} = useNote(id)
|
|
const {
|
|
handleNodesCopy,
|
|
handleNodesDuplicate,
|
|
handleNodeDelete,
|
|
} = useNodesInteractions()
|
|
const { handleNodeDataUpdateWithSyncDraft } = useNodeDataUpdate()
|
|
|
|
const handleDeleteNode = useCallback(() => {
|
|
handleNodeDelete(id)
|
|
}, [id, handleNodeDelete])
|
|
|
|
useClickAway(() => {
|
|
handleNodeDataUpdateWithSyncDraft({ id, data: { selected: false } })
|
|
}, ref)
|
|
|
|
return (
|
|
<div
|
|
className={cn(
|
|
'flex flex-col relative rounded-md shadow-xs border hover:shadow-md',
|
|
THEME_MAP[theme].bg,
|
|
data.selected ? THEME_MAP[theme].border : 'border-black/5',
|
|
)}
|
|
style={{
|
|
width: data.width,
|
|
height: data.height,
|
|
}}
|
|
ref={ref}
|
|
>
|
|
<NoteEditorContextProvider
|
|
key={controlPromptEditorRerenderKey}
|
|
value={data.text}
|
|
>
|
|
<>
|
|
<NodeResizer
|
|
nodeId={id}
|
|
nodeData={data}
|
|
icon={<Icon />}
|
|
minWidth={240}
|
|
minHeight={88}
|
|
/>
|
|
<div
|
|
className={cn(
|
|
'shrink-0 h-2 opacity-50 rounded-t-md',
|
|
THEME_MAP[theme].title,
|
|
)}></div>
|
|
{
|
|
data.selected && (
|
|
<div className='absolute -top-[41px] left-1/2 -translate-x-1/2'>
|
|
<NoteEditorToolbar
|
|
theme={theme}
|
|
onThemeChange={handleThemeChange}
|
|
onCopy={handleNodesCopy}
|
|
onDuplicate={handleNodesDuplicate}
|
|
onDelete={handleDeleteNode}
|
|
showAuthor={data.showAuthor}
|
|
onShowAuthorChange={handleShowAuthorChange}
|
|
/>
|
|
</div>
|
|
)
|
|
}
|
|
<div className='grow px-3 py-2.5 overflow-y-auto'>
|
|
<div className={cn(
|
|
data.selected && 'nodrag nopan nowheel cursor-text',
|
|
)}>
|
|
<NoteEditor
|
|
containerElement={ref.current}
|
|
placeholder={t('workflow.nodes.note.editor.placeholder') || ''}
|
|
onChange={handleEditorChange}
|
|
/>
|
|
</div>
|
|
</div>
|
|
{
|
|
data.showAuthor && (
|
|
<div className='p-3 pt-0 text-xs text-text-tertiary'>
|
|
{data.author}
|
|
</div>
|
|
)
|
|
}
|
|
</>
|
|
</NoteEditorContextProvider>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default memo(NoteNode)
|