mirror of
https://git.mirrors.martin98.com/https://github.com/langgenius/dify.git
synced 2025-05-14 18:08:17 +08:00

Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Yeuoly <admin@srmxy.cn> Co-authored-by: JzoNg <jzongcode@gmail.com> Co-authored-by: StyleZhang <jasonapring2015@outlook.com> Co-authored-by: jyong <jyong@dify.ai> Co-authored-by: nite-knite <nkCoding@gmail.com> Co-authored-by: jyong <718720800@qq.com>
75 lines
1.8 KiB
TypeScript
75 lines
1.8 KiB
TypeScript
import {
|
|
memo,
|
|
useEffect,
|
|
} from 'react'
|
|
import {
|
|
$insertNodes,
|
|
COMMAND_PRIORITY_EDITOR,
|
|
createCommand,
|
|
} from 'lexical'
|
|
import { mergeRegister } from '@lexical/utils'
|
|
import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext'
|
|
import type { ContextBlockType } from '../../types'
|
|
import {
|
|
$createContextBlockNode,
|
|
ContextBlockNode,
|
|
} from './node'
|
|
|
|
export const INSERT_CONTEXT_BLOCK_COMMAND = createCommand('INSERT_CONTEXT_BLOCK_COMMAND')
|
|
export const DELETE_CONTEXT_BLOCK_COMMAND = createCommand('DELETE_CONTEXT_BLOCK_COMMAND')
|
|
|
|
export type Dataset = {
|
|
id: string
|
|
name: string
|
|
type: string
|
|
}
|
|
|
|
const ContextBlock = memo(({
|
|
datasets = [],
|
|
onAddContext = () => {},
|
|
onInsert,
|
|
onDelete,
|
|
canNotAddContext,
|
|
}: ContextBlockType) => {
|
|
const [editor] = useLexicalComposerContext()
|
|
|
|
useEffect(() => {
|
|
if (!editor.hasNodes([ContextBlockNode]))
|
|
throw new Error('ContextBlockPlugin: ContextBlock not registered on editor')
|
|
|
|
return mergeRegister(
|
|
editor.registerCommand(
|
|
INSERT_CONTEXT_BLOCK_COMMAND,
|
|
() => {
|
|
const contextBlockNode = $createContextBlockNode(datasets, onAddContext, canNotAddContext)
|
|
|
|
$insertNodes([contextBlockNode])
|
|
|
|
if (onInsert)
|
|
onInsert()
|
|
|
|
return true
|
|
},
|
|
COMMAND_PRIORITY_EDITOR,
|
|
),
|
|
editor.registerCommand(
|
|
DELETE_CONTEXT_BLOCK_COMMAND,
|
|
() => {
|
|
if (onDelete)
|
|
onDelete()
|
|
|
|
return true
|
|
},
|
|
COMMAND_PRIORITY_EDITOR,
|
|
),
|
|
)
|
|
}, [editor, datasets, onAddContext, onInsert, onDelete, canNotAddContext])
|
|
|
|
return null
|
|
})
|
|
ContextBlock.displayName = 'ContextBlock'
|
|
|
|
export { ContextBlock }
|
|
export { ContextBlockNode } from './node'
|
|
export { default as ContextBlockReplacementBlock } from './context-block-replacement-block'
|