@next-bricks/ai-portal 0.64.4 → 0.64.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bricks.json +9 -9
- package/dist/chunks/{4820.3f60d55c.js → 4820.d3be9b94.js} +2 -2
- package/dist/chunks/4820.d3be9b94.js.map +1 -0
- package/dist/chunks/{9271.24992b40.js → 9271.2786528c.js} +2 -2
- package/dist/chunks/9271.2786528c.js.map +1 -0
- package/dist/chunks/chat-panel.a3dafde9.js +2 -0
- package/dist/chunks/chat-panel.a3dafde9.js.map +1 -0
- package/dist/chunks/{main.0d63781a.js → main.87744001.js} +2 -2
- package/dist/chunks/{main.0d63781a.js.map → main.87744001.js.map} +1 -1
- package/dist/examples.json +3 -3
- package/dist/{index.682d62ca.js → index.00f609de.js} +2 -2
- package/dist/{index.682d62ca.js.map → index.00f609de.js.map} +1 -1
- package/dist/manifest.json +19 -19
- package/dist/types.json +500 -500
- package/package.json +2 -2
- package/dist/chunks/4820.3f60d55c.js.map +0 -1
- package/dist/chunks/9271.24992b40.js.map +0 -1
- package/dist/chunks/chat-panel.0735e831.js +0 -2
- package/dist/chunks/chat-panel.0735e831.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/9271.24992b40.js","mappings":"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","sources":["webpack:///./src/shared/FileUpload/i18n.ts","webpack:///./src/shared/FileUpload/validateFiles.ts","webpack:///./src/shared/FileUpload/GlobalDragOverlay.module.css?40e0","webpack:///./src/shared/FileUpload/GlobalDragOverlay.tsx","webpack:///../../src/getCaretPositionInTextarea.ts","webpack:///../../src/getContentRectsInTextarea.ts","webpack:///./src/shared/ChatCompletions/useChatCompletions.ts","webpack:///./src/shared/FileUpload/GlobalDragOverlay.module.css","webpack:///./src/shared/FileUpload/UploadedFiles.tsx","webpack:///./src/shared/useFilesUploading.ts","webpack:///./src/shared/FileUpload/UploadedFiles.shadow.css","webpack:///./src/shared/FileUpload/UploadButton.tsx","webpack:///../../../src/utils/getMirroredStyle.ts","webpack:///../../../src/utils/calculateAutoSizeStyle.ts","webpack:///../../src/TextareaAutoResize.tsx"],"sourcesContent":["import { i18n, initializeI18n } from \"@next-core/i18n\";\n\nexport enum K {\n UPLOAD_FILES = \"UPLOAD_FILES\",\n UPLOADING = \"UPLOADING\",\n UPLOAD_FAILED = \"UPLOAD_FAILED\",\n DROP_FILES_HERE = \"DROP_FILES_HERE\",\n SUPPORTED_FILE_TYPES = \"SUPPORTED_FILE_TYPES\",\n UNSUPPORTED_FILE_TYPE = \"UNSUPPORTED_FILE_TYPE\",\n MAX_SIZE_EXCEEDED = \"MAX_SIZE_EXCEEDED\",\n MAX_SIZE_EXCEEDED_UNKNOWN = \"MAX_SIZE_EXCEEDED_UNKNOWN\",\n MAX_FILES_EXCEEDED = \"MAX_FILES_EXCEEDED\",\n}\n\nconst en: Locale = {\n UPLOAD_FILES: \"Upload files\",\n UPLOADING: \"Uploading...\",\n UPLOAD_FAILED: \"Upload failed\",\n DROP_FILES_HERE: \"Drop files here\",\n SUPPORTED_FILE_TYPES: \"Supported file types: {{types}}.\",\n UNSUPPORTED_FILE_TYPE: \"Some files have unsupported file types.\",\n MAX_SIZE_EXCEEDED: \"Maximum single file size: {{size}}.\",\n MAX_SIZE_EXCEEDED_UNKNOWN: \"Some files exceed the maximum allowed size.\",\n MAX_FILES_EXCEEDED: \"Maximum number of files ({{count}}) exceeded.\",\n};\n\nconst zh: Locale = {\n UPLOAD_FILES: \"上传文件\",\n UPLOADING: \"上传中...\",\n UPLOAD_FAILED: \"上传失败\",\n DROP_FILES_HERE: \"在此处拖放文件\",\n SUPPORTED_FILE_TYPES: \"仅支持以下文件类型:{{types}}。\",\n UNSUPPORTED_FILE_TYPE: \"部分文件类型不受支持。\",\n MAX_SIZE_EXCEEDED: \"单个文件不能超过 {{size}}。\",\n MAX_SIZE_EXCEEDED_UNKNOWN: \"部分文件超过允许的最大大小。\",\n MAX_FILES_EXCEEDED: \"超过允许的最大文件数量 ({{count}})。\",\n};\n\nexport const NS = \"bricks/ai-portal/FileUpload\";\n\nexport const locales = { en, zh };\n\nexport const t = i18n.getFixedT(null, NS);\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n\ninitializeI18n(NS, locales);\n","import { handleHttpError } from \"@next-core/runtime\";\nimport type { UploadOptions } from \"../interfaces\";\nimport { K, t } from \"./i18n\";\n\nexport function validateFiles(files: File[], options: UploadOptions) {\n const acceptedTypes = options.accept\n ? options.accept.split(\",\").map((type) => type.trim())\n : null;\n\n for (const file of files) {\n if (acceptedTypes) {\n const mimeType = file.type;\n const accepted = acceptedTypes.some((type) => {\n if (type === \"*/*\" || type === \"*\") {\n return true;\n }\n if (type.startsWith(\".\")) {\n return file.name.toLowerCase().endsWith(type.toLowerCase());\n }\n if (type.endsWith(\"/*\")) {\n const baseType = type.split(\"/\")[0];\n return mimeType.startsWith(`${baseType}/`);\n }\n return mimeType === type;\n });\n if (!accepted) {\n handleHttpError(\n options.readableAccept\n ? t(K.SUPPORTED_FILE_TYPES, { types: options.readableAccept })\n : t(K.UNSUPPORTED_FILE_TYPE)\n );\n return false;\n }\n }\n\n if (options.maxSize && file.size > options.maxSize) {\n handleHttpError(\n options.readableMaxSize\n ? t(K.MAX_SIZE_EXCEEDED, { size: options.readableMaxSize })\n : t(K.MAX_SIZE_EXCEEDED_UNKNOWN)\n );\n return false;\n }\n }\n\n return true;\n}\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./GlobalDragOverlay.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./GlobalDragOverlay.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef, useState } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport dragImage from \"./drag-file@2x.png\";\nimport { K, t } from \"./i18n\";\nimport styles from \"./GlobalDragOverlay.module.css\";\nimport { validateFiles } from \"./validateFiles\";\nimport type { UploadOptions } from \"../interfaces\";\n\nexport interface GlobalDragOverlayProps {\n disabled?: boolean;\n uploadOptions?: UploadOptions;\n onFilesDropped?: (files: File[]) => void;\n}\n\nexport default function GlobalDragOverlay({\n disabled,\n uploadOptions,\n onFilesDropped,\n}: GlobalDragOverlayProps) {\n const [isDragging, setIsDragging] = useState(false);\n const dragCounterRef = useRef(0);\n\n useEffect(() => {\n if (disabled) {\n dragCounterRef.current = 0;\n setIsDragging(false);\n return;\n }\n\n const handleDragEnter = (e: DragEvent) => {\n e.preventDefault();\n e.stopPropagation();\n\n for (const target of e.composedPath()) {\n if (\n target instanceof HTMLElement &&\n (target.tagName === \"EO-DRAWER\" || target.tagName === \"EO-MODAL\")\n ) {\n return;\n }\n }\n\n // 只在拖入文件时触发(排除文字、链接等)\n const hasFiles = Array.from(e.dataTransfer?.items || []).some(\n (item) => item.kind === \"file\"\n );\n if (!hasFiles) return;\n\n dragCounterRef.current++;\n setIsDragging(true);\n };\n\n const handleDragLeave = (e: DragEvent) => {\n e.preventDefault();\n e.stopPropagation();\n if (dragCounterRef.current > 0) {\n dragCounterRef.current--;\n }\n if (dragCounterRef.current === 0) setIsDragging(false);\n };\n\n const handleDragOver = (e: DragEvent) => {\n e.preventDefault();\n e.stopPropagation();\n };\n\n const handleDrop = (e: DragEvent) => {\n e.preventDefault();\n e.stopPropagation();\n\n dragCounterRef.current = 0;\n setIsDragging(false);\n\n const files = Array.from(e.dataTransfer!.files);\n if (files.length > 0) {\n const allFilesAccepted = validateFiles(files, uploadOptions!);\n if (allFilesAccepted) {\n onFilesDropped?.(files);\n }\n }\n };\n\n window.addEventListener(\"dragenter\", handleDragEnter);\n window.addEventListener(\"dragleave\", handleDragLeave);\n window.addEventListener(\"dragover\", handleDragOver);\n window.addEventListener(\"drop\", handleDrop);\n\n return () => {\n window.removeEventListener(\"dragenter\", handleDragEnter);\n window.removeEventListener(\"dragleave\", handleDragLeave);\n window.removeEventListener(\"dragover\", handleDragOver);\n window.removeEventListener(\"drop\", handleDrop);\n };\n }, [disabled, uploadOptions, onFilesDropped]);\n\n if (!isDragging) {\n return null;\n }\n\n return createPortal(\n <div className={styles.overlay}>\n <img src={dragImage} width=\"91\" height=\"79\" />\n <div className={styles.title}>{t(K.DROP_FILES_HERE)}</div>\n <div className={styles.description}>{uploadOptions?.dragTips}</div>\n </div>,\n document.body\n );\n}\n","import { getMirroredStyle } from \"./utils/getMirroredStyle.js\";\n\nlet hiddenElement: HTMLDivElement | undefined;\n\nexport function getCaretPositionInTextarea(\n textarea: HTMLTextAreaElement,\n index: number\n) {\n if (!hiddenElement) {\n hiddenElement = document.createElement(\"div\");\n hiddenElement.setAttribute(\"tab-index\", \"-1\");\n hiddenElement.setAttribute(\"aria-hidden\", \"true\");\n document.body.appendChild(hiddenElement);\n }\n\n hiddenElement.setAttribute(\"style\", getMirroredStyle(textarea));\n hiddenElement.textContent = textarea.value.slice(0, index);\n\n const span = document.createElement(\"span\");\n span.textContent = \"\\u200b\"; // 占位符\n hiddenElement.appendChild(span);\n\n const rect = span.getBoundingClientRect();\n span.remove();\n return {\n top: rect.top,\n left: rect.left,\n };\n}\n","import { getMirroredStyle } from \"./utils/getMirroredStyle.js\";\n\nlet hiddenElement: HTMLDivElement | undefined;\n\nexport function getContentRectsInTextarea(\n textarea: HTMLTextAreaElement,\n prefix: string,\n measureContent: string\n): DOMRect[] {\n if (!hiddenElement) {\n hiddenElement = document.createElement(\"div\");\n hiddenElement.setAttribute(\"tab-index\", \"-1\");\n hiddenElement.setAttribute(\"aria-hidden\", \"true\");\n document.body.appendChild(hiddenElement);\n }\n hiddenElement.setAttribute(\"style\", getMirroredStyle(textarea));\n\n hiddenElement.textContent = prefix;\n\n const span = document.createElement(\"span\");\n span.textContent = measureContent;\n hiddenElement.appendChild(span);\n\n const fullRect = span.getBoundingClientRect();\n span.remove();\n\n if (measureContent.length <= 1) {\n return [fullRect];\n }\n\n const leadingChar = measureContent[0];\n const leadingSpan = document.createElement(\"span\");\n leadingSpan.textContent = leadingChar;\n hiddenElement.appendChild(leadingSpan);\n const leadingRect = leadingSpan.getBoundingClientRect();\n leadingSpan.remove();\n\n hiddenElement.textContent = `${prefix}${measureContent.slice(0, -1)}`;\n const trailingChar = measureContent[measureContent.length - 1];\n const trailingSpan = document.createElement(\"span\");\n trailingSpan.textContent = trailingChar;\n hiddenElement.appendChild(trailingSpan);\n const trailingRect = trailingSpan.getBoundingClientRect();\n trailingSpan.remove();\n\n if (leadingRect.top === trailingRect.top) {\n return [fullRect];\n }\n\n const rects: DOMRect[] = [];\n\n // Leading rect\n rects.push(\n new DOMRect(\n leadingRect.left,\n leadingRect.top,\n fullRect.right - leadingRect.left,\n leadingRect.bottom - leadingRect.top\n )\n );\n\n // Middle rect\n const height = trailingRect.top - leadingRect.bottom;\n if (height >= 10) {\n rects.push(\n new DOMRect(fullRect.left, leadingRect.bottom, fullRect.width, height)\n );\n }\n\n // Trailing rect\n rects.push(\n new DOMRect(\n fullRect.left,\n trailingRect.top,\n trailingRect.right - fullRect.left,\n trailingRect.bottom - trailingRect.top\n )\n );\n\n return rects;\n}\n","import { useCallback, useEffect, useRef, useState } from \"react\";\nimport type { SimpleAction } from \"@next-bricks/basic/actions\";\nimport {\n getCaretPositionInTextarea,\n getContentRectsInTextarea,\n type TextareaAutoResizeRef,\n} from \"@next-shared/form\";\nimport type { CommandPayload } from \"../interfaces\";\nimport { getInitialContent } from \"../ReadableCommand/ReadableCommand\";\nimport type { ChatCommand } from \"../../data-providers/set-chat-command\";\n\nexport const MAX_SHOWN_COMMANDS = 10;\n\nexport interface MentionPopover {\n style: React.CSSProperties;\n range: {\n start: number;\n end: number;\n };\n actions: ActionWithSubCommands[];\n}\n\nexport type ActionWithSubCommands = SimpleAction & {\n key: string | number;\n subCommands?: Command[];\n payload?: CommandPayload;\n};\n\nexport interface Command {\n label: string;\n value: string;\n groupKey?: string;\n groupLabel?: string;\n subCommands?: Command[];\n payload?: CommandPayload;\n}\n\nexport interface AIEmployee {\n employeeId: string;\n name: string;\n}\n\nexport interface UseChatMentionsParams {\n aiEmployees?: AIEmployee[];\n commands?: Command[];\n root: HTMLElement;\n hasFiles: boolean;\n /** @default \"bottom\" */\n placement?: \"top\" | \"bottom\";\n}\n\nexport function useChatCompletions({\n aiEmployees,\n commands: propCommands,\n root,\n hasFiles,\n placement,\n}: UseChatMentionsParams) {\n const textareaRef = useRef<TextareaAutoResizeRef>(null);\n const [value, setValue] = useState(\"\");\n const valueRef = useRef(\"\");\n const [activeActionIndex, setActiveActionIndex] = useState(0);\n const selectionRef = useRef<{ start: number; end: number } | null>(null);\n\n // Mentions start\n const [mentionPopover, setMentionPopover] = useState<MentionPopover | null>(\n null\n );\n const [mentionOverlay, setMentionOverlay] = useState<\n React.CSSProperties[] | null\n >(null);\n const [mentionedText, setMentionedText] = useState(\"\");\n const [mentioned, setMentioned] = useState<string | null>(null);\n const [initialMention, setInitialMention] = useState<string | null>(null);\n\n const showMentionSuggestions = useCallback(\n (textarea: HTMLTextAreaElement, employees: AIEmployee[] | undefined) => {\n const { value, selectionStart, selectionEnd } = textarea;\n if (\n selectionStart !== null &&\n selectionStart === selectionEnd &&\n employees?.length\n ) {\n const previousContent = value.slice(0, selectionStart);\n if (previousContent.startsWith(\"@\")) {\n const mentionText = previousContent.slice(1).toLowerCase();\n const matchedEmployees = employees\n .filter(\n (employee) =>\n employee.employeeId.toLowerCase().includes(mentionText) ||\n employee.name.toLowerCase().includes(mentionText)\n )\n .slice(0, MAX_SHOWN_COMMANDS);\n if (matchedEmployees.length > 0) {\n const position = getCaretPositionInTextarea(\n textarea,\n selectionStart\n );\n const textareaRect = textarea.getBoundingClientRect();\n setMentionPopover({\n style: {\n left: position.left + 10 + textareaRect.left,\n ...(placement === \"top\"\n ? {\n bottom:\n window.innerHeight - textareaRect.top - position.top,\n }\n : { top: position.top + 22 + textareaRect.top }),\n position: \"absolute\",\n zIndex: 1,\n },\n range: { start: 0, end: selectionStart },\n actions: matchedEmployees.map((employee) => ({\n key: employee.employeeId,\n text: employee.name,\n data: employee,\n })),\n });\n setActiveActionIndex(0);\n return true;\n }\n }\n }\n setMentionPopover(null);\n },\n [placement]\n );\n\n // Show mention suggestions once candidates are loaded\n const mentionInitializedRef = useRef(false);\n useEffect(() => {\n const textarea = textareaRef.current?.element;\n if (\n mentionInitializedRef.current ||\n !aiEmployees ||\n !textarea ||\n document.activeElement !== root ||\n root.shadowRoot?.activeElement !== textarea\n ) {\n return;\n }\n mentionInitializedRef.current = true;\n showMentionSuggestions(textarea, aiEmployees);\n }, [aiEmployees, root, textareaRef, showMentionSuggestions]);\n\n useEffect(() => {\n if (mentionedText && !value.startsWith(mentionedText)) {\n setMentionedText(\"\");\n setMentioned(null);\n }\n }, [mentionedText, value]);\n\n useEffect(() => {\n const element = textareaRef.current?.element;\n if (!mentionedText || !element) {\n setMentionOverlay(null);\n return;\n }\n setMentionOverlay(getOverlayRects(element, mentionedText));\n }, [mentionedText, hasFiles]);\n\n useEffect(() => {\n const element = textareaRef.current?.element;\n if (initialMention && element) {\n setMentioned(initialMention);\n const mentionStr = `${getInitialContent(undefined, initialMention)} `;\n setMentionOverlay(getOverlayRects(element, mentionStr));\n valueRef.current = mentionStr;\n selectionRef.current = {\n start: mentionStr.length,\n end: mentionStr.length,\n };\n setValue(mentionStr);\n setMentionedText(mentionStr);\n }\n }, [initialMention]);\n\n const handleMention = useCallback(\n (action: SimpleAction) => {\n const mention = `@${action.text} `;\n const prefix = `${valueRef.current.slice(0, mentionPopover!.range.start)}${mention}`;\n const newValue = `${prefix}${valueRef.current.slice(mentionPopover!.range.end)}`;\n valueRef.current = newValue;\n selectionRef.current = { start: prefix.length, end: prefix.length };\n setValue(newValue);\n setMentionedText(mention);\n setMentionPopover(null);\n setMentioned((action as { data?: AIEmployee }).data!.employeeId);\n textareaRef.current?.focus();\n },\n [mentionPopover]\n );\n // Mentions end\n\n // Commands start\n const [commandPrefix, setCommandPrefix] = useState(\"/\");\n const [commands, setCommands] = useState<Command[] | undefined>(propCommands);\n const [command, setCommand] = useState<CommandPayload | null>(null);\n const [commandPopover, setCommandPopover] = useState<MentionPopover | null>(\n null\n );\n const [commandOverlay, setCommandOverlay] = useState<\n React.CSSProperties[] | null\n >(null);\n const [commandText, setCommandText] = useState(\"\");\n const [initialCommand, setInitialCommand] = useState<ChatCommand | null>(\n null\n );\n\n useEffect(() => {\n setCommands(propCommands);\n }, [propCommands]);\n\n const showCommandSuggestions = useCallback(\n (\n textarea: HTMLTextAreaElement,\n commandList: Command[] | undefined,\n prefix: string\n ) => {\n const { value, selectionStart, selectionEnd } = textarea;\n if (\n selectionStart !== null &&\n selectionStart === selectionEnd &&\n commandList?.length\n ) {\n const previousContent = value.slice(0, selectionStart);\n if (previousContent.startsWith(prefix)) {\n const searchText = previousContent.slice(prefix.length).toLowerCase();\n const matchedCommands = commandList\n .filter(\n (command) =>\n command.label.toLowerCase().includes(searchText) ||\n command.groupLabel?.toLowerCase().includes(searchText)\n )\n .slice(0, MAX_SHOWN_COMMANDS);\n if (matchedCommands.length > 0) {\n const popover = getCommandPopover(\n matchedCommands,\n textarea,\n selectionStart,\n placement\n );\n setCommandPopover(popover);\n setActiveActionIndex(0);\n return true;\n }\n }\n }\n setCommandPopover(null);\n },\n [placement]\n );\n\n // Show command suggestions once candidates are loaded\n const commandsInitializedRef = useRef(false);\n useEffect(() => {\n const textarea = textareaRef.current?.element;\n if (\n commandsInitializedRef.current ||\n !propCommands ||\n !textarea ||\n document.activeElement !== root ||\n root.shadowRoot?.activeElement !== textarea\n ) {\n return;\n }\n commandsInitializedRef.current = true;\n showCommandSuggestions(textarea, propCommands, \"/\");\n }, [propCommands, root, showCommandSuggestions]);\n\n useEffect(() => {\n if (\n !value.startsWith(commandPrefix) ||\n (commandText && !value.startsWith(commandText))\n ) {\n setCommandText(\"\");\n setCommand(null);\n setCommands(propCommands);\n setCommandPrefix(\"/\");\n setCommandPopover(null);\n }\n }, [commandPrefix, commandText, value, propCommands]);\n\n useEffect(() => {\n const element = textareaRef.current?.element;\n if (!commandText || !element) {\n setCommandOverlay(null);\n return;\n }\n setCommandOverlay(getOverlayRects(element, commandText));\n }, [commandText, hasFiles]);\n\n useEffect(() => {\n const element = textareaRef.current?.element;\n if (initialCommand && element) {\n setCommand(initialCommand.payload);\n const commandStr = `/${initialCommand.command} `;\n setCommandOverlay(getOverlayRects(element, commandStr));\n valueRef.current = commandStr;\n selectionRef.current = {\n start: commandStr.length,\n end: commandStr.length,\n };\n setValue(commandStr);\n setCommandText(commandStr);\n }\n }, [initialCommand]);\n\n const handleSelectCommand = useCallback(\n (action: ActionWithSubCommands) => {\n const hasSubCommands =\n action.subCommands && action.subCommands.length > 0;\n const command = `${commandPrefix.replace(/ $/, \": \")}${action.text} `;\n const prefix = `${valueRef.current.slice(0, commandPopover!.range.start)}${command}`;\n const newValue = `${prefix}${valueRef.current.slice(commandPopover!.range.end)}`;\n valueRef.current = newValue;\n selectionRef.current = { start: prefix.length, end: prefix.length };\n setValue(newValue);\n if (hasSubCommands) {\n if (action.payload) {\n setCommandText(command);\n setCommand(action.payload);\n }\n setCommands(action.subCommands);\n setCommandPrefix(command);\n // Wait for the textarea to update\n setTimeout(() => {\n const popover = getCommandPopover(\n action.subCommands!.slice(0, MAX_SHOWN_COMMANDS),\n textareaRef.current!.element!,\n prefix.length,\n placement\n );\n setCommandPopover(popover);\n setActiveActionIndex(0);\n }, 100);\n } else {\n setCommandText(command);\n setCommand(action.payload!);\n setCommandPopover(null);\n setCommandPrefix(\"/\");\n }\n textareaRef.current?.focus();\n },\n [commandPopover, commandPrefix, placement]\n );\n // Commands end\n\n const handleChange = useCallback(\n (e: React.ChangeEvent<HTMLTextAreaElement>) => {\n const { value } = e.target;\n valueRef.current = value;\n setValue(value);\n\n if (showMentionSuggestions(e.target, aiEmployees)) {\n return;\n }\n showCommandSuggestions(e.target, commands, commandPrefix);\n },\n [\n aiEmployees,\n commandPrefix,\n commands,\n showCommandSuggestions,\n showMentionSuggestions,\n ]\n );\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent<HTMLTextAreaElement>) => {\n switch (e.key) {\n case \"Escape\":\n if (!mentionPopover && !commandPopover) {\n return;\n }\n e.preventDefault();\n e.stopPropagation();\n e.nativeEvent.stopImmediatePropagation();\n setMentionPopover(null);\n setCommandPopover(null);\n return false;\n case \"ArrowUp\":\n case \"ArrowDown\": {\n if (!mentionPopover && !commandPopover) {\n return;\n }\n e.preventDefault();\n e.stopPropagation();\n e.nativeEvent.stopImmediatePropagation();\n setActiveActionIndex((prev) => {\n const nextIndex = prev + (e.key === \"ArrowUp\" ? -1 : 1);\n const meaningfulActions = getMeaningfulActions(\n (mentionPopover || commandPopover)!.actions\n );\n const total = meaningfulActions.length;\n const next = (total + nextIndex) % total;\n return next;\n });\n return false;\n }\n case \"Enter\": {\n if (!mentionPopover && !commandPopover) {\n return;\n }\n e.preventDefault();\n e.stopPropagation();\n e.nativeEvent.stopImmediatePropagation();\n const activeAction = getMeaningfulActions(\n (mentionPopover || commandPopover)!.actions\n )[activeActionIndex];\n if (mentionPopover) {\n handleMention(activeAction);\n } else {\n handleSelectCommand(activeAction);\n }\n return false;\n }\n case \"Delete\":\n case \"Backspace\": {\n const popovers = [\n {\n textLength: mentionedText.length,\n prefixLength: 0,\n },\n {\n textLength: commandText.length,\n prefixLength: 0,\n },\n ];\n\n for (const { textLength, prefixLength } of popovers) {\n if (textLength) {\n let { selectionStart, selectionEnd } = e.currentTarget;\n if (selectionStart === selectionEnd) {\n if (e.key === \"Backspace\") {\n selectionStart -= 1;\n } else {\n selectionEnd += 1;\n }\n }\n const currentStart = prefixLength;\n const currentEnd = currentStart + textLength;\n if (selectionStart < currentEnd && selectionEnd > currentStart) {\n const start = Math.min(selectionStart, currentStart);\n const end = Math.max(selectionEnd, currentEnd);\n const newValue = `${valueRef.current.slice(0, start)}${valueRef.current.slice(end)}`;\n valueRef.current = newValue;\n selectionRef.current = { start, end: start };\n setValue(newValue);\n e.preventDefault();\n e.stopPropagation();\n return false;\n }\n }\n }\n break;\n }\n }\n },\n [\n activeActionIndex,\n commandPopover,\n commandText.length,\n handleMention,\n handleSelectCommand,\n mentionPopover,\n mentionedText.length,\n ]\n );\n\n const mentionActiveKeys = mentionPopover\n ? getActiveActionKeys(mentionPopover.actions, activeActionIndex)\n : null;\n const commandActiveKeys = commandPopover\n ? getActiveActionKeys(commandPopover.actions, activeActionIndex)\n : null;\n\n return {\n textareaRef,\n valueRef,\n value,\n setValue,\n selectionRef,\n\n mentioned,\n mentionedText,\n mentionPopover,\n mentionOverlay,\n mentionActiveKeys,\n setInitialMention,\n handleMention,\n\n command,\n commandText,\n commandPrefix,\n commandPopover,\n commandOverlay,\n commandActiveKeys,\n setInitialCommand,\n handleSelectCommand,\n\n handleChange,\n handleKeyDown,\n };\n}\n\nfunction getActiveActionKeys(\n actions: ActionWithSubCommands[],\n index: number\n): (string | number)[] {\n const meaningfulActions = getMeaningfulActions(actions);\n return [meaningfulActions[index].key!];\n}\n\nfunction getMeaningfulActions(\n actions: ActionWithSubCommands[]\n): ActionWithSubCommands[] {\n return actions.filter(\n (action) =>\n (action as any).type !== \"group\" && (action as any).type !== \"divider\"\n );\n}\n\nfunction getOverlayRects(element: HTMLTextAreaElement, content: string) {\n const rects = getContentRectsInTextarea(\n element,\n \"\",\n // Ignore the last space\n content.slice(0, -1)\n );\n return rects.map((rect) => ({\n left: rect.left - 1,\n top: rect.top - 1,\n width: rect.width + 4,\n height: rect.height + 4,\n }));\n}\n\nfunction getCommandPopover(\n commands: Command[],\n textarea: HTMLTextAreaElement,\n selectionStart: number,\n placement?: \"top\" | \"bottom\"\n): MentionPopover {\n const position = getCaretPositionInTextarea(textarea, selectionStart);\n const textareaRect = textarea.getBoundingClientRect();\n return {\n style: {\n left: position.left + 10 + textareaRect.left,\n ...(placement === \"top\"\n ? { bottom: window.innerHeight - textareaRect.top - position.top }\n : { top: position.top + 22 + textareaRect.top }),\n position: \"absolute\",\n zIndex: 1,\n },\n range: { start: 0, end: selectionStart },\n actions: getGroupedCommandActions(commands),\n };\n}\n\nfunction getGroupedCommandActions(\n commands: Command[]\n): ActionWithSubCommands[] {\n const grouped = commands.every((cmd) => cmd.groupKey && cmd.groupLabel);\n if (grouped) {\n const groups = new Map<string, { label: string; commands: Command[] }>();\n for (const command of commands) {\n const groupKey = command.groupKey!;\n let group = groups.get(groupKey);\n if (!group) {\n groups.set(\n groupKey,\n (group = {\n label: command.groupLabel!,\n commands: [],\n })\n );\n }\n group.commands.push(command);\n }\n return [...groups.values()].flatMap((group) => [\n {\n type: \"group\",\n text: group.label,\n },\n ...getCommandActions(group.commands),\n ]) as ActionWithSubCommands[];\n }\n\n return getCommandActions(commands);\n}\n\nfunction getCommandActions(commands: Command[]): ActionWithSubCommands[] {\n return commands.map((command) => ({\n key: command.value,\n text: command.label,\n subCommands: command.subCommands,\n payload: command.payload,\n }));\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.overlay--SI1oXhAV{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(255,255,255,0.1);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);display:flex;align-items:center;justify-content:center;flex-direction:column;z-index:9999}.title--FmBT01QV{font-weight:600;font-size:20px;color:rgba(0,0,0,0.88);line-height:28px;margin-top:17px}.description--Yhdhm5wT{color:rgba(0,0,0,0.45);font-size:14px;margin-top:11px}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"overlay\": `overlay--SI1oXhAV`,\n\t\"title\": `title--FmBT01QV`,\n\t\"description\": `description--Yhdhm5wT`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","import React, { useEffect, useState } from \"react\";\nimport classNames from \"classnames\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type { FileItem } from \"./interfaces\";\nimport {\n formatFileSize,\n getFileTypeAndIcon,\n} from \"../../cruise-canvas/utils/file\";\nimport { K, t } from \"./i18n\";\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nexport interface UploadedFilesProps {\n files: FileItem[];\n maxFiles?: number;\n className?: string;\n onRemove: (uid: number, abortController: AbortController | undefined) => void;\n onAdd: () => void;\n}\n\nexport function UploadedFiles({\n files,\n maxFiles,\n className,\n onRemove,\n onAdd,\n}: UploadedFilesProps) {\n const showAsImage = files.every((file) =>\n file.file.type.startsWith(\"image/\")\n );\n\n return (\n <ul\n className={classNames(\"files\", className)}\n onClick={(e) => {\n e.stopPropagation();\n }}\n >\n {files.map((file) => (\n <FileComponent\n {...file}\n key={file.uid}\n showAsImage={showAsImage}\n onRemove={onRemove}\n />\n ))}\n {!maxFiles || files.length < maxFiles ? (\n <li>\n <button className=\"btn-add-file\" onClick={onAdd}>\n <WrappedIcon lib=\"antd\" icon=\"plus\" />\n </button>\n </li>\n ) : null}\n </ul>\n );\n}\n\ninterface FileComponentProps extends FileItem {\n showAsImage?: boolean;\n onRemove: (uid: number, abortController: AbortController | undefined) => void;\n}\n\nfunction FileComponent({\n uid,\n file,\n status,\n abortController,\n showAsImage,\n onRemove,\n}: FileComponentProps) {\n const [type, icon] = getFileTypeAndIcon(file.type, file.name);\n const size = formatFileSize(file.size);\n const isImage = file.type.startsWith(\"image/\");\n const [image, setImage] = useState<string | undefined>();\n\n useEffect(() => {\n if (isImage) {\n const url = URL.createObjectURL(file);\n setImage(url);\n return () => {\n URL.revokeObjectURL(url);\n };\n } else {\n setImage(undefined);\n }\n }, [file, isImage]);\n\n const buttonRemove = (\n <button\n className=\"file-remove\"\n onClick={() => {\n onRemove(uid, abortController);\n }}\n >\n <WrappedIcon lib=\"antd\" theme=\"filled\" icon=\"close-circle\" />\n </button>\n );\n\n if (showAsImage) {\n return (\n <li\n className={classNames(\"file as-image\", { failed: status === \"failed\" })}\n >\n <img className=\"file-image\" src={image} />\n {status === \"uploading\" && (\n <div className=\"file-overlay\">\n <WrappedIcon lib=\"antd\" icon=\"loading-3-quarters\" spinning />\n </div>\n )}\n {status === \"failed\" && (\n <div className=\"file-overlay\">{t(K.UPLOAD_FAILED)}</div>\n )}\n {buttonRemove}\n </li>\n );\n }\n\n return (\n <li\n className={classNames(\"file\", {\n failed: status === \"failed\",\n uploading: status === \"uploading\",\n })}\n >\n {isImage ? (\n <img className=\"file-image\" src={image} />\n ) : (\n <img className=\"file-icon\" src={icon} width={26} height={32} />\n )}\n <div className=\"file-content\">\n <div className=\"file-name\">{file.name}</div>\n <div className=\"file-metadata\">\n <span className=\"file-status\">\n {`${status === \"uploading\" ? t(K.UPLOADING) : status === \"failed\" ? t(K.UPLOAD_FAILED) : type}`}\n </span>\n {` · ${size}`}\n </div>\n </div>\n {buttonRemove}\n </li>\n );\n}\n","import { useCallback, useEffect, useRef, useState } from \"react\";\nimport { handleHttpError } from \"@next-core/runtime\";\nimport { http } from \"@next-core/http\";\nimport type { FileItem } from \"./FileUpload/interfaces\";\nimport type { UploadFileInfo, UploadOptions } from \"./interfaces\";\nimport { validateFiles } from \"./FileUpload/validateFiles\";\nimport { K, t } from \"./FileUpload/i18n\";\n\nlet uid = 0;\n\nexport function getNextUid() {\n return uid++;\n}\n\nexport function useFilesUploading(options?: UploadOptions) {\n const enabled = options?.enabled;\n const maxFiles = options?.maxFiles;\n const [files, setFiles] = useState<FileItem[] | undefined>();\n const hasFiles = !!files && files.length > 0;\n\n useEffect(() => {\n files?.forEach(async (fileItem) => {\n if (fileItem.status === \"ready\") {\n const abortController = new AbortController();\n\n setFiles((prevFiles) => {\n return prevFiles?.map((item) => {\n if (item.uid === fileItem.uid) {\n return { ...item, status: \"uploading\", abortController };\n }\n return item;\n });\n });\n\n try {\n const formData = new FormData();\n formData.append(\"file\", fileItem.file);\n\n const response = await http.request<{ data: UploadFileInfo }>(\n \"api/gateway/logic.llm.aiops_service/api/v1/elevo/files/upload\",\n {\n method: \"POST\",\n body: formData,\n signal: abortController.signal,\n },\n {\n interceptorParams: {\n ignoreLoadingBar: true,\n },\n }\n );\n\n setFiles((prevFiles) => {\n return prevFiles?.map((item) => {\n if (item.uid === fileItem.uid) {\n return {\n ...item,\n status: \"done\",\n fileInfo: response.data,\n };\n }\n return item;\n });\n });\n } catch (error) {\n setFiles((prevFiles) => {\n return prevFiles?.map((item) => {\n if (item.uid === fileItem.uid) {\n return { ...item, status: \"failed\" };\n }\n return item;\n });\n });\n handleHttpError(error);\n }\n }\n });\n }, [files]);\n\n const [allFilesDone, setAllFilesDone] = useState(true);\n const [fileInfos, setFileInfos] = useState<UploadFileInfo[] | undefined>();\n const initialRef = useRef(true);\n\n useEffect(() => {\n const allFilesDone =\n !files || files.every((file) => file.status === \"done\");\n setAllFilesDone(allFilesDone);\n if (initialRef.current) {\n initialRef.current = false;\n return;\n }\n if (allFilesDone) {\n setFileInfos(files?.map((file) => file.fileInfo!));\n }\n }, [files]);\n\n const appendFiles = useCallback(\n (newFiles: File[]) => {\n if (!validateFiles(newFiles, options!)) {\n return;\n }\n\n setFiles((prev) => {\n const prevList = prev ?? [];\n if (maxFiles && prevList.length + newFiles.length > maxFiles) {\n handleHttpError(t(K.MAX_FILES_EXCEEDED, { count: maxFiles }));\n return prev;\n }\n return [\n ...prevList,\n ...newFiles.map<FileItem>((file) => ({\n uid: getNextUid(),\n file,\n status: \"ready\",\n })),\n ];\n });\n },\n [maxFiles, options]\n );\n\n const resetFiles = useCallback(() => {\n setFiles(undefined);\n }, []);\n\n const removeFile = useCallback((uid: number) => {\n setFiles((prev) => prev?.filter((file) => file.uid !== uid));\n }, []);\n\n const exceeded = !!maxFiles && !!files && files.length >= maxFiles;\n\n const paste = useCallback(\n (e: React.ClipboardEvent<HTMLTextAreaElement>) => {\n if (!enabled) {\n return;\n }\n const fileList = e.clipboardData.files;\n if (fileList.length > 0 && enabled) {\n e.preventDefault();\n e.stopPropagation();\n const files = [...fileList];\n const allFilesAccepted = validateFiles(files, options!);\n if (allFilesAccepted) {\n appendFiles(files);\n }\n }\n },\n [enabled, options, appendFiles]\n );\n\n return {\n files,\n resetFiles,\n appendFiles,\n removeFile,\n hasFiles,\n allFilesDone,\n fileInfos,\n exceeded,\n paste,\n };\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.files{list-style:none;margin:0;padding:4px 0 0;position:absolute;display:flex;gap:8px;top:10px;left:16px;right:16px;overflow-x:auto}.file{background:rgba(0,0,0,0.04);border-radius:6px;display:flex;width:200px;height:60px;align-items:center;padding:0 8px;position:relative}.file.uploading::before{content:\"\";position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,0.06);border-radius:6px;animation:loadingAnimation 1.5s linear infinite}@keyframes loadingAnimation{0%{right:100%}100%{right:0}}.file-content{min-width:0;flex:1}.file-icon{margin:0 11px 0 6px}.file-image{margin-right:8px;object-fit:container;border-radius:4px;max-width:44px;max-height:44px}.file-name,\n.file-metadata{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-name{color:rgba(0,0,0,0.88)}.file-metadata{color:rgba(0,0,0,0.45);font-size:12px;margin-top:3px}.file-remove{position:absolute;top:-4px;right:-4px;font-size:12px;padding:1px;display:flex;color:rgba(0,0,0,0.88);cursor:pointer;background:#fff;border-radius:14px}.file:not(:hover) .file-remove{display:none}.btn-add-file{border-radius:6px;border:1px dashed rgba(0,0,0,0.1);color:rgba(0,0,0,0.45);font-size:16px;display:flex;width:60px;height:60px;align-items:center;justify-content:center;cursor:pointer}.btn-add-file:hover{background:rgba(0,0,0,0.04)}.file.failed .file-status{color:var(--color-error)}.file.as-image{width:60px;border:1px solid rgba(0,0,0,0.1);padding:0;background:none;justify-content:center}.file.as-image .file-image{max-width:100%;max-height:100%;margin:0;border-radius:6px}.file.as-image.failed{border-color:#f24c25}.file-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(0,10,26,0.45);border-radius:6px;color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;font-size:20px}.file.failed .file-overlay{background:rgba(0,10,26,0.7);color:#ff754f;font-size:12px}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","import React, { forwardRef, useImperativeHandle, useRef } from \"react\";\nimport type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport type { IconButton, IconButtonProps } from \"../../icon-button\";\nimport { K, t } from \"./i18n\";\n\nconst WrappedIconButton = wrapBrick<IconButton, IconButtonProps>(\n \"ai-portal.icon-button\"\n);\n\nconst ICON_UPLOAD: GeneralIconProps = {\n lib: \"lucide\",\n icon: \"paperclip\",\n};\n\nexport interface UploadButtonProps {\n accept?: string;\n disabled?: boolean;\n onChange?: (files: File[]) => void;\n}\n\nexport interface UploadButtonRef {\n requestUpload: () => void;\n}\n\nexport const UploadButton = forwardRef(LegacyUploadButton);\n\nfunction LegacyUploadButton(\n { accept, disabled, onChange }: UploadButtonProps,\n ref: React.Ref<UploadButtonRef>\n) {\n const inputRef = useRef<HTMLInputElement>(null);\n\n const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const files = e.target.files;\n if (files) {\n onChange?.(Array.from(files));\n }\n e.target.value = \"\";\n };\n\n useImperativeHandle(ref, () => ({\n requestUpload: () => {\n inputRef.current?.click();\n },\n }));\n\n return (\n <>\n <input\n type=\"file\"\n accept={accept}\n multiple\n hidden\n ref={inputRef}\n onChange={handleInputChange}\n onClick={(e) => {\n e.stopPropagation();\n }}\n />\n <WrappedIconButton\n variant=\"light\"\n className=\"btn-upload\"\n icon={ICON_UPLOAD}\n tooltip={t(K.UPLOAD_FILES)}\n disabled={disabled}\n onClick={(e) => {\n e.stopPropagation();\n inputRef.current?.click();\n }}\n />\n </>\n );\n}\n","const HIDDEN_STYLE = `\n min-height: 0!important;\n max-height: none!important;\n height: 0!important;\n visibility: hidden!important;\n overflow: hidden!important;\n position: absolute!important;\n z-index: -1000!important;\n top: 0!important;\n left: 0!important;\n pointer-events: none!important;\n`;\n\nconst SIZING_STYLE = [\n \"letter-spacing\",\n \"line-height\",\n \"padding-top\",\n \"padding-bottom\",\n \"font-family\",\n \"font-weight\",\n \"font-size\",\n \"font-variant\",\n \"text-rendering\",\n \"text-transform\",\n \"width\",\n \"text-indent\",\n \"padding-left\",\n \"padding-right\",\n \"border-width\",\n \"box-sizing\",\n \"word-break\",\n \"white-space\",\n];\n\n/**\n * 创建一个镜像元素,用于计算光标位置或文本尺寸。\n */\nexport function getMirroredStyle(element: HTMLElement) {\n const uiTextNodeStyle = window.getComputedStyle(element);\n const sizingStyle = SIZING_STYLE.map(\n (name) => `${name}:${uiTextNodeStyle.getPropertyValue(name)}`\n ).join(\";\");\n return `${sizingStyle};${HIDDEN_STYLE}`;\n}\n","// istanbul ignore file\nimport type React from \"react\";\nimport { getMirroredStyle } from \"./getMirroredStyle.js\";\n\nlet hiddenTextarea: HTMLTextAreaElement | undefined;\n\nexport interface AutoSizeOptions {\n minRows?: number | null;\n maxRows?: number | null;\n borderSize?: number;\n paddingSize?: number;\n}\n\n/**\n * 计算 textarea 高度\n * https://github.com/react-component/textarea/blob/1c0026fbe30e5f7dff1fca695b2cf262246381ca/src/calculateNodeHeight.tsx\n */\nexport default function calculateAutoSizeStyle(\n uiTextNode: HTMLTextAreaElement,\n options?: AutoSizeOptions\n): React.CSSProperties {\n const {\n minRows = null,\n maxRows = null,\n borderSize = 2,\n paddingSize = 8,\n } = options ?? {};\n\n if (!hiddenTextarea) {\n hiddenTextarea = document.createElement(\"textarea\");\n hiddenTextarea.setAttribute(\"tab-index\", \"-1\");\n hiddenTextarea.setAttribute(\"aria-hidden\", \"true\");\n document.body.appendChild(hiddenTextarea);\n }\n\n // equal style\n hiddenTextarea.setAttribute(\"style\", getMirroredStyle(uiTextNode));\n hiddenTextarea.value = uiTextNode.value || uiTextNode.placeholder || \"\";\n\n let minHeight: number | undefined;\n let maxHeight: number | undefined;\n let overflowY: React.CSSProperties[\"overflowY\"];\n\n let height = hiddenTextarea.scrollHeight + borderSize;\n\n if (minRows !== null || maxRows !== null) {\n const singleRowHeight =\n process.env.NODE_ENV === \"test\"\n ? 22\n : parseFloat(\n window\n .getComputedStyle(hiddenTextarea)\n .getPropertyValue(\"line-height\")\n );\n if (minRows !== null) {\n minHeight = singleRowHeight * minRows + paddingSize + borderSize;\n height = Math.max(minHeight, height);\n }\n if (maxRows !== null) {\n maxHeight = singleRowHeight * maxRows + paddingSize + borderSize;\n if (height <= maxHeight) {\n overflowY = \"hidden\";\n }\n height = Math.min(maxHeight, height);\n }\n }\n\n const style: React.CSSProperties = {\n height,\n overflowY,\n resize: \"none\",\n };\n\n if (minHeight) {\n style.minHeight = minHeight;\n }\n if (maxHeight) {\n style.maxHeight = maxHeight;\n }\n\n return style;\n}\n","import React, {\n useCallback,\n useEffect,\n useImperativeHandle,\n useLayoutEffect,\n useRef,\n useState,\n} from \"react\";\nimport { flushSync } from \"react-dom\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport calculateAutoSizeStyle from \"./utils/calculateAutoSizeStyle.js\";\n\n// istanbul ignore next\nconst modKey = /Mac|iPod|iPhone|iPad/.test(navigator.platform)\n ? \"metaKey\"\n : \"ctrlKey\";\n\nexport interface TextareaAutoResizeProps\n extends React.DetailedHTMLProps<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n HTMLTextAreaElement\n > {\n /** @default true */\n autoResize?: boolean;\n minRows?: number | null;\n maxRows?: number | null;\n /** @default 2 */\n borderSize?: number;\n /** @default 8 */\n paddingSize?: number;\n containerRef?: React.RefObject<HTMLElement>;\n submitWhen?: \"enter-without-shift\" | \"enter-with-mod\";\n desiredSelectionRef?: React.MutableRefObject<{\n start: number;\n end: number;\n } | null>;\n onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>) => void;\n /**\n * The handler can return false to prevent default behavior (submit)\n */\n onKeyDown?: (e: React.KeyboardEvent<HTMLTextAreaElement>) => void | false;\n}\n\nexport interface TextareaAutoResizeRef {\n focus(): void;\n element: HTMLTextAreaElement | null;\n}\n\nexport const TextareaAutoResize = React.forwardRef<\n TextareaAutoResizeRef,\n TextareaAutoResizeProps\n>(LegacyTextareaAutoResize);\n\nfunction LegacyTextareaAutoResize(\n {\n autoResize: _autoResize,\n minRows,\n maxRows,\n borderSize,\n paddingSize,\n containerRef,\n value: propValue,\n style,\n submitWhen,\n desiredSelectionRef,\n onChange,\n onSubmit,\n onKeyDown,\n onCompositionStart,\n onCompositionEnd,\n ...props\n }: TextareaAutoResizeProps,\n ref: React.ForwardedRef<TextareaAutoResizeRef>\n): React.JSX.Element {\n const autoResize = _autoResize ?? true;\n const [value, setValue] = useState(propValue ?? \"\");\n const textareaRef = useRef<HTMLTextAreaElement>(null);\n const [autoStyle, setAutoStyle] = useState<React.CSSProperties | null>(null);\n\n useImperativeHandle(\n ref,\n () => ({\n focus: () => {\n const textarea = textareaRef.current;\n // istanbul ignore else: defensive check\n if (textarea) {\n const valueLength = textarea.value?.length;\n textarea.focus();\n valueLength && textarea.setSelectionRange(valueLength, valueLength);\n }\n },\n element: textareaRef.current,\n }),\n []\n );\n\n const doAutoResize = useCallback(() => {\n const textarea = textareaRef.current;\n if (textarea && autoResize) {\n const style = calculateAutoSizeStyle(textarea, {\n minRows,\n maxRows,\n borderSize,\n paddingSize,\n });\n // istanbul ignore next\n if (process.env.NODE_ENV === \"test\") {\n setAutoStyle(style);\n } else {\n flushSync(() => {\n setAutoStyle(style);\n });\n }\n }\n }, [autoResize, maxRows, minRows, borderSize, paddingSize]);\n\n const handleInputChange = (\n e: React.ChangeEvent<HTMLTextAreaElement>\n ): void => {\n setValue(e.target.value);\n onChange?.(e);\n };\n\n useEffect(() => {\n setValue(propValue ?? \"\");\n }, [propValue]);\n\n useEffect(() => {\n doAutoResize();\n }, [doAutoResize, value]);\n\n const compositionRef = useRef(false);\n\n const handleCompositionStart = useCallback(\n (e: React.CompositionEvent<HTMLTextAreaElement>) => {\n compositionRef.current = true;\n onCompositionStart?.(e);\n },\n [onCompositionStart]\n );\n\n const handleCompositionEnd = useCallback(\n (e: React.CompositionEvent<HTMLTextAreaElement>) => {\n compositionRef.current = false;\n onCompositionEnd?.(e);\n },\n [onCompositionEnd]\n );\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent<HTMLTextAreaElement>) => {\n if (compositionRef.current) {\n // Ignore key events during composition\n return;\n }\n\n if (onKeyDown?.(e) === false) {\n return;\n }\n\n if (\n e.key === \"Enter\" &&\n (submitWhen === \"enter-without-shift\"\n ? !e.shiftKey\n : submitWhen === \"enter-with-mod\" && e[modKey])\n ) {\n e.preventDefault();\n e.stopPropagation();\n onSubmit?.(e);\n }\n },\n [onKeyDown, onSubmit, submitWhen]\n );\n\n useLayoutEffect(() => {\n const desiredSelection = desiredSelectionRef?.current;\n const textarea = textareaRef.current;\n if (desiredSelection && textarea) {\n const { start, end } = desiredSelection;\n desiredSelectionRef.current = null;\n textarea.setSelectionRange(start, end);\n }\n }, [desiredSelectionRef, value]);\n\n // istanbul ignore next\n useEffect(() => {\n const container = containerRef?.current;\n if (!container || !autoResize) {\n return;\n }\n let previousInlineSize: number | undefined;\n const observer = new ResizeObserver((entries) => {\n for (const entry of entries) {\n if (entry.target === container) {\n // istanbul ignore next: compatibility\n const currentInlineSize = entry.contentBoxSize\n ? entry.contentBoxSize[0]\n ? entry.contentBoxSize[0].inlineSize\n : (entry.contentBoxSize as unknown as ResizeObserverSize)\n .inlineSize\n : entry.contentRect.width;\n if (\n currentInlineSize !== undefined &&\n currentInlineSize !== previousInlineSize\n ) {\n const isInitial = !previousInlineSize;\n previousInlineSize = currentInlineSize;\n if (!isInitial) {\n requestAnimationFrame(doAutoResize);\n }\n }\n }\n }\n });\n observer.observe(container);\n return () => {\n observer.disconnect();\n };\n }, [autoResize, containerRef, doAutoResize]);\n\n return (\n <textarea\n {...props}\n ref={textareaRef}\n value={value}\n style={{\n ...style,\n ...autoStyle,\n }}\n onChange={handleInputChange}\n onCompositionStart={handleCompositionStart}\n onCompositionEnd={handleCompositionEnd}\n onKeyDown={handleKeyDown}\n />\n );\n}\n"],"names":["K","NS","t","i18n","getFixedT","initializeI18n","en","UPLOAD_FILES","UPLOADING","UPLOAD_FAILED","DROP_FILES_HERE","SUPPORTED_FILE_TYPES","UNSUPPORTED_FILE_TYPE","MAX_SIZE_EXCEEDED","MAX_SIZE_EXCEEDED_UNKNOWN","MAX_FILES_EXCEEDED","zh","validateFiles","files","options","acceptedTypes","accept","split","map","type","trim","file","mimeType","some","startsWith","name","toLowerCase","endsWith","baseType","handleHttpError","readableAccept","types","maxSize","size","readableMaxSize","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","locals","undefined","GlobalDragOverlay","_ref","disabled","uploadOptions","onFilesDropped","isDragging","setIsDragging","useState","dragCounterRef","useRef","useEffect","current","handleDragEnter","e","_e$dataTransfer","preventDefault","stopPropagation","target","composedPath","HTMLElement","tagName","Array","from","dataTransfer","items","item","kind","handleDragLeave","handleDragOver","handleDrop","length","window","addEventListener","removeEventListener","createPortal","React","className","styles","overlay","src","dragImage","width","height","title","description","dragTips","document","body","hiddenElement","getCaretPositionInTextarea","textarea","index","createElement","setAttribute","appendChild","getMirroredStyle","textContent","value","slice","span","rect","getBoundingClientRect","remove","top","left","MAX_SHOWN_COMMANDS","useChatCompletions","aiEmployees","commands","propCommands","root","hasFiles","placement","textareaRef","setValue","valueRef","activeActionIndex","setActiveActionIndex","selectionRef","mentionPopover","setMentionPopover","mentionOverlay","setMentionOverlay","mentionedText","setMentionedText","mentioned","setMentioned","initialMention","setInitialMention","showMentionSuggestions","useCallback","employees","selectionStart","selectionEnd","previousContent","mentionText","matchedEmployees","filter","employee","employeeId","includes","position","textareaRect","style","bottom","innerHeight","zIndex","range","start","end","actions","key","text","data","mentionInitializedRef","_textareaRef$current","_root$shadowRoot","element","activeElement","shadowRoot","_textareaRef$current2","getOverlayRects","_textareaRef$current3","mentionStr","getInitialContent","handleMention","action","_textareaRef$current4","mention","prefix","newValue","focus","commandPrefix","setCommandPrefix","setCommands","command","setCommand","commandPopover","setCommandPopover","commandOverlay","setCommandOverlay","commandText","setCommandText","initialCommand","setInitialCommand","showCommandSuggestions","commandList","searchText","matchedCommands","_command$groupLabel","label","groupLabel","popover","getCommandPopover","commandsInitializedRef","_textareaRef$current5","_root$shadowRoot2","_textareaRef$current6","_textareaRef$current7","payload","commandStr","handleSelectCommand","_textareaRef$current8","hasSubCommands","subCommands","replace","setTimeout","handleChange","handleKeyDown","nativeEvent","stopImmediatePropagation","prev","nextIndex","total","getMeaningfulActions","activeAction","popovers","textLength","prefixLength","currentTarget","currentStart","currentEnd","Math","min","max","mentionActiveKeys","getActiveActionKeys","commandActiveKeys","content","measureContent","fullRect","leadingChar","leadingSpan","leadingRect","trailingChar","trailingSpan","trailingRect","rects","push","DOMRect","right","getContentRectsInTextarea","getGroupedCommandActions","every","cmd","groupKey","groups","Map","group","get","set","values","flatMap","getCommandActions","___CSS_LOADER_EXPORT___","module","id","WrappedIcon","wrapBrick","UploadedFiles","maxFiles","onRemove","onAdd","showAsImage","classNames","onClick","FileComponent","_extends","uid","lib","icon","_ref2","status","abortController","getFileTypeAndIcon","formatFileSize","isImage","image","setImage","url","URL","createObjectURL","revokeObjectURL","buttonRemove","theme","failed","spinning","uploading","useFilesUploading","enabled","setFiles","forEach","async","fileItem","AbortController","prevFiles","formData","FormData","append","response","http","request","method","signal","interceptorParams","ignoreLoadingBar","fileInfo","error","allFilesDone","setAllFilesDone","fileInfos","setFileInfos","initialRef","appendFiles","newFiles","prevList","count","resetFiles","removeFile","exceeded","paste","fileList","clipboardData","toString","WrappedIconButton","ICON_UPLOAD","UploadButton","forwardRef","LegacyUploadButton","ref","onChange","inputRef","useImperativeHandle","requestUpload","_inputRef$current","click","multiple","hidden","variant","tooltip","_inputRef$current2","HIDDEN_STYLE","SIZING_STYLE","uiTextNodeStyle","getComputedStyle","getPropertyValue","join","hiddenTextarea","modKey","test","navigator","platform","TextareaAutoResize","LegacyTextareaAutoResize","autoResize","_autoResize","minRows","maxRows","borderSize","paddingSize","containerRef","propValue","submitWhen","desiredSelectionRef","onSubmit","onKeyDown","onCompositionStart","onCompositionEnd","props","autoStyle","setAutoStyle","_textarea$value","valueLength","setSelectionRange","doAutoResize","uiTextNode","minHeight","maxHeight","overflowY","placeholder","scrollHeight","singleRowHeight","parseFloat","resize","calculateAutoSizeStyle","flushSync","compositionRef","handleCompositionStart","handleCompositionEnd","shiftKey","useLayoutEffect","desiredSelection","container","previousInlineSize","observer","ResizeObserver","entries","entry","currentInlineSize","contentBoxSize","inlineSize","contentRect","isInitial","requestAnimationFrame","observe","disconnect"],"sourceRoot":""}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(globalThis.webpackChunk_next_bricks_ai_portal=globalThis.webpackChunk_next_bricks_ai_portal||[]).push([[288],{8337:(e,t,s)=>{s.d(t,{A:()=>g});var a=s(72591),l=s.n(a),n=s(1740),i=s.n(n),o=s(88128),r=s.n(o),c=s(30855),h=s.n(c),u=s(93051),d=s.n(u),p=s(73656),m=s.n(p),A=s(55111),v={};v.styleTagTransform=m(),v.setAttributes=h(),v.insert=r().bind(null,"head"),v.domAPI=i(),v.insertStyleElement=d(),l()(A.A,v);const g=A.A&&A.A.locals?A.A.locals:void 0},11552:(e,t,s)=>{s.r(t),s.d(t,{ChatPanel:()=>te});var a,l=s(70918),n=s(86121),i=s(70829),o=s(62740),r=s(18769),c=s.n(r),h=s(90870),u=s(30981),d=(s(34419),s(22919)),p=s(18796),m=s(8337),A=s(60128),v=s(67101),g=s(13330),f=s(52208),k=s(40563),b=s(30621),E=s(84766),w=s(9442),y=s(69493),I=s(32360),T=s(40177),C=s(30672),x=s(38717),B=s(6671),R=s(76720);let M,N,F,O,S,W,P,V,_,j,Z,D,G,H,L,U,$,q,K,z;const Q=(0,u.wrapBrick)("eo-modal",{onClose:"close",onConfirm:"confirm",onCancel:"cancel",onOpen:"open"}),{defineElement:J,property:X,method:Y}=(0,h.createDecorators)(),ee=(0,r.forwardRef)(pe);let te;var se=new WeakMap,ae=new WeakMap,le=new WeakMap,ne=new WeakMap,ie=new WeakMap,oe=new WeakMap,re=new WeakMap,ce=new WeakMap,he=new WeakMap,ue=new WeakMap;class de extends u.ReactNextElement{constructor(){super(...arguments),(0,l.A)(this,se,(M(this),F(this))),(0,l.A)(this,ae,(O(this),S(this))),(0,l.A)(this,le,(W(this),P(this))),(0,l.A)(this,ne,(V(this),_(this))),(0,l.A)(this,ie,(j(this),Z(this))),(0,l.A)(this,oe,(D(this),G(this))),(0,l.A)(this,re,(H(this),L(this))),(0,l.A)(this,ce,(U(this),$(this))),(0,l.A)(this,he,(q(this),K(this))),(0,l.A)(this,ue,(z(this),(0,r.createRef)()))}get panelTitle(){return(0,i.A)(se,this)}set panelTitle(e){(0,n.A)(se,this,e)}get aiEmployeeId(){return(0,i.A)(ae,this)}set aiEmployeeId(e){(0,n.A)(ae,this,e)}get cmd(){return(0,i.A)(le,this)}set cmd(e){(0,n.A)(le,this,e)}get width(){return(0,i.A)(ne,this)}set width(e){(0,n.A)(ne,this,e)}get height(){return(0,i.A)(ie,this)}set height(e){(0,n.A)(ie,this,e)}get placeholder(){return(0,i.A)(oe,this)}set placeholder(e){(0,n.A)(oe,this,e)}get uploadOptions(){return(0,i.A)(re,this)}set uploadOptions(e){(0,n.A)(re,this,e)}get help(){return(0,i.A)(ce,this)}set help(e){(0,n.A)(ce,this,e)}get maskClosable(){return(0,i.A)(he,this)}set maskClosable(e){(0,n.A)(he,this,e)}open(){var e;null===(e=(0,i.A)(ue,this).current)||void 0===e||e.open()}close(){var e;null===(e=(0,i.A)(ue,this).current)||void 0===e||e.close()}setInputValue(e){var t;null===(t=(0,i.A)(ue,this).current)||void 0===t||t.setInputValue(e)}send(e){var t;null===(t=(0,i.A)(ue,this).current)||void 0===t||t.send(e)}showFile(e){var t;null===(t=(0,i.A)(ue,this).current)||void 0===t||t.showFile(e)}render(){return c().createElement(ee,{ref:(0,i.A)(ue,this),panelTitle:this.panelTitle,aiEmployeeId:this.aiEmployeeId,cmd:this.cmd,width:this.width,height:this.height,placeholder:this.placeholder,uploadOptions:this.uploadOptions,help:this.help,maskClosable:this.maskClosable})}}function pe(e,t){let{panelTitle:s,aiEmployeeId:a,cmd:l,width:n,height:i,placeholder:o,uploadOptions:h,help:u,maskClosable:M}=e;const N=(0,r.useRef)(null),F=(0,r.useRef)(null),[O,S]=(0,r.useState)(!1),[W,P]=(0,r.useState)(null),[V,_]=(0,r.useState)(null),{conversation:j,tasks:Z,errors:D,humanInputRef:G}=(0,v.u)(W,V),H=!!j,L=null==j?void 0:j.state,U=T.QB.includes(L),$=!W||U||"input-required"===L,{messages:q}=(0,g.p)(H,L,Z,D),K=(0,r.useCallback)(((e,t,s)=>{var a;null===(a=G.current)||void 0===a||a.call(G,e,t,s)}),[G]),[z,J]=(0,r.useState)(!1);(0,r.useEffect)((()=>{let e=!1;return Promise.race([(0,f.L)("light-plus"),new Promise((e=>setTimeout(e,5e3)))]).finally((()=>{e||J(!0)})),()=>{e=!0}}),[]);const X=(0,r.useRef)(null),Y=(0,r.useRef)(null),{scrollable:ee,scrollToBottom:te}=(0,k.i)(H&&z,X,Y),se=(0,r.useCallback)((async e=>{if(W){const{content:t,...s}=e;K(t,void 0,s)}else{S(!0);try{const t=(await d.http.post("api/gateway/logic.llm.aiops_service/api/v1/elevo/conversations",{})).data.conversationId;P(t),_({...e,...a?{aiEmployeeId:a}:null,...l?{cmd:l}:null,conversationId:t})}catch(e){(0,A.handleHttpError)(e)}finally{S(!1)}}}),[a,l,W,K]),[ae,le]=(0,r.useState)(null),[ne,ie]=(0,r.useState)(null),oe=(0,r.useMemo)((()=>({conversationState:L,setActiveFile:le,setActiveImages:ie,humanInput:K})),[L,K]);(0,r.useImperativeHandle)(t,(()=>({open:()=>{var e;null===(e=N.current)||void 0===e||e.open()},close:()=>{var e;null===(e=N.current)||void 0===e||e.close()},setInputValue:e=>{var t;null===(t=F.current)||void 0===t||t.setValue(e)},send:e=>{se(e)},showFile:e=>{le(e)}})),[se]);const re=(null==j?void 0:j.finished)&&!T.Z5.includes(L);return c().createElement(R.j.Provider,{value:oe},c().createElement(Q,{modalTitle:s,width:n,height:i,themeVariant:"elevo",maskClosable:M,noFooter:!0,headerBordered:!0,fullscreenButton:!0,background:`fixed url(${I}) center center / cover no-repeat`,onOpen:()=>{setTimeout((()=>{var e;null===(e=F.current)||void 0===e||e.focus()}),100)},ref:N},c().createElement("div",{className:m.A.panel},W?H&&z?c().createElement("div",{className:m.A.main},c().createElement("div",{className:m.A.chat,ref:X},c().createElement("div",{className:m.A.messages,ref:Y},q.map(((e,t,s)=>c().createElement("div",{className:m.A.message,key:t},"user"===e.role?c().createElement(b.R,{content:e.content,files:e.files}):c().createElement(E.G,{chunks:e.chunks,scopeState:j.state,isLatest:t===s.length-1&&!re,finished:j.finished})))),re&&c().createElement("div",{className:m.A.message},c().createElement(E.G,{earlyFinished:!0})))),c().createElement("button",{className:`${w.A["scroll-down"]} ${y.A["floating-button"]}`,style:{bottom:"30px"},hidden:!ee,onClick:te},c().createElement(C.Bj,{lib:"antd",icon:"down"}))):c().createElement("div",{className:m.A["loading-icon"]},c().createElement(C.Bj,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0})):c().createElement("div",{className:m.A.main},u?c().createElement(p.ReactUseMultipleBricks,{useBrick:u.useBrick}):null),c().createElement("div",{className:m.A.input},c().createElement(C.IV,{ref:F,placeholder:o,suggestionsPlacement:"top",submitDisabled:O||!$,supportsTerminate:!0,uploadOptions:h,onChatSubmit:e=>se(e.detail)})))),ae&&c().createElement(x.d,{file:ae,fromModal:!0}),ne&&c().createElement(B.f,{images:ne,fromModal:!0}))}a=de,({e:[F,O,S,W,P,V,_,j,Z,D,G,H,L,U,$,q,K,z,M],c:[te,N]}=(0,o.A)(a,[J("ai-portal.chat-panel",{shadowOptions:!1})],[[X(),1,"panelTitle"],[X(),1,"aiEmployeeId"],[X({attribute:!1}),1,"cmd"],[X({attribute:!1}),1,"width"],[X({attribute:!1}),1,"height"],[X(),1,"placeholder"],[X({attribute:!1}),1,"uploadOptions"],[X({attribute:!1}),1,"help"],[X({type:Boolean}),1,"maskClosable"],[Y(),2,"open"],[Y(),2,"close"],[Y(),2,"setInputValue"],[Y(),2,"send"],[Y(),2,"showFile"]],0,void 0,u.ReactNextElement)),N()},55111:(e,t,s)=>{s.d(t,{A:()=>o});var a=s(36758),l=s.n(a),n=s(40935),i=s.n(n)()(l());i.push([e.id,".panel--ukaGUcR2{display:flex;flex-direction:column;min-height:300px;height:100%}.main--K5R8dLH9{position:relative;flex:1;min-height:0}.chat--Drl2ThnZ{padding:0 0 20px;height:100%;overflow-y:auto}.messages--Bhaarj69{width:100%;margin:0 auto}.message--TP5bdFpZ + .message--TP5bdFpZ{margin-top:40px}.loading-icon--BjI0pCV1{flex:1;display:flex;align-items:center;justify-content:center;font-size:48px;color:#fff}",""]),i.locals={panel:"panel--ukaGUcR2",main:"main--K5R8dLH9",chat:"chat--Drl2ThnZ",messages:"messages--Bhaarj69",message:"message--TP5bdFpZ","loading-icon":"loading-icon--BjI0pCV1"};const o=i}}]);
|
|
2
|
-
//# sourceMappingURL=chat-panel.0735e831.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/chat-panel.0735e831.js","mappings":"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","sources":["webpack:///./src/chat-panel/styles.module.css?bf50","webpack:///./src/chat-panel/index.tsx","webpack:///./src/chat-panel/styles.module.css"],"sourcesContent":["\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./styles.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./styles.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, {\n createRef,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport type {\n Modal,\n ModalProps,\n ModalEvents,\n ModalMapEvents,\n} from \"@next-bricks/containers/modal\";\nimport { http } from \"@next-core/http\";\nimport type { UseBrickConf } from \"@next-core/types\";\nimport { ReactUseMultipleBricks } from \"@next-core/react-runtime\";\nimport styles from \"./styles.module.css\";\nimport type { ChatInput } from \"../chat-input\";\nimport type {\n ActiveImages,\n ChatPayload,\n CommandPayload,\n ExtraChatPayload,\n FileInfo,\n RequestStore,\n UploadOptions,\n} from \"../shared/interfaces\";\nimport { handleHttpError } from \"@next-core/runtime\";\nimport { useConversationDetail } from \"../cruise-canvas/useConversationDetail\";\nimport { useConversationStream } from \"../chat-stream/useConversationStream\";\nimport { preloadHighlighter } from \"@next-shared/markdown\";\nimport { useAutoScroll } from \"../chat-stream/useAutoScroll\";\nimport { UserMessage } from \"../chat-stream/UserMessage/UserMessage\";\nimport { AssistantMessage } from \"../chat-stream/AssistantMessage/AssistantMessage\";\nimport scrollStyles from \"../chat-stream/ScrollDownButton.module.css\";\nimport floatingStyles from \"../shared/FloatingButton.module.css\";\nimport backgroundImage from \"../home-container/images/background.png\";\nimport { DONE_STATES, NON_WORKING_STATES } from \"../shared/constants\";\nimport { WrappedChatInput, WrappedIcon } from \"../shared/bricks\";\nimport { FilePreview } from \"../shared/FilePreview/FilePreview.js\";\nimport { ImagesPreview } from \"../shared/FilePreview/ImagesPreview.js\";\nimport { TaskContext, type TaskContextValue } from \"../shared/TaskContext\";\n\nconst WrappedModal = wrapBrick<\n Modal,\n ModalProps & {\n themeVariant?: \"default\" | \"elevo\";\n height?: string | number;\n noFooter?: boolean;\n headerBordered?: boolean;\n background?: string;\n fullscreenButton?: boolean;\n },\n ModalEvents,\n ModalMapEvents\n>(\"eo-modal\", {\n onClose: \"close\",\n onConfirm: \"confirm\",\n onCancel: \"cancel\",\n onOpen: \"open\",\n});\n\nconst { defineElement, property, method } = createDecorators();\n\nexport interface ChatPanelProps {\n panelTitle?: string;\n aiEmployeeId?: string;\n cmd?: CommandPayload;\n width?: string | number;\n height?: string | number;\n placeholder?: string;\n uploadOptions?: UploadOptions;\n help?: { useBrick: UseBrickConf };\n maskClosable?: boolean;\n}\n\nconst ChatPanelComponent = forwardRef(LegacyChatPanelComponent);\n\n/**\n * 弹出式对话面板。\n */\nexport\n@defineElement(\"ai-portal.chat-panel\", {\n shadowOptions: false,\n})\nclass ChatPanel extends ReactNextElement implements ChatPanelProps {\n @property()\n accessor panelTitle: string | undefined;\n\n @property()\n accessor aiEmployeeId: string | undefined;\n\n @property({ attribute: false })\n accessor cmd: CommandPayload | undefined;\n\n @property({ attribute: false }) accessor width: string | number | undefined;\n\n @property({ attribute: false }) accessor height: string | number | undefined;\n\n @property()\n accessor placeholder: string | undefined;\n\n @property({ attribute: false })\n accessor uploadOptions: UploadOptions | undefined;\n\n /**\n * Show help messages when no conversation exists.\n */\n @property({ attribute: false })\n accessor help: { useBrick: UseBrickConf } | undefined;\n\n /**\n * Whether to close the panel when clicking the mask.\n *\n * @default false\n */\n @property({ type: Boolean })\n accessor maskClosable: boolean | undefined;\n\n #ref = createRef<ChatPanelRef>();\n\n @method()\n open() {\n this.#ref.current?.open();\n }\n\n @method()\n close() {\n this.#ref.current?.close();\n }\n\n @method()\n setInputValue(content: string) {\n this.#ref.current?.setInputValue(content);\n }\n\n @method()\n send(payload: ChatPayload) {\n this.#ref.current?.send(payload);\n }\n\n @method()\n showFile(file: FileInfo) {\n this.#ref.current?.showFile(file);\n }\n\n render() {\n return (\n <ChatPanelComponent\n ref={this.#ref}\n panelTitle={this.panelTitle}\n aiEmployeeId={this.aiEmployeeId}\n cmd={this.cmd}\n width={this.width}\n height={this.height}\n placeholder={this.placeholder}\n uploadOptions={this.uploadOptions}\n help={this.help}\n maskClosable={this.maskClosable}\n />\n );\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\ninterface ChatPanelComponentProps extends ChatPanelProps {\n // Define react event handlers here.\n}\n\ninterface ChatPanelRef {\n open: () => void;\n close: () => void;\n setInputValue: (content: string) => void;\n send: (payload: ChatPayload) => void;\n showFile: (file: FileInfo) => void;\n}\n\nfunction LegacyChatPanelComponent(\n {\n panelTitle,\n aiEmployeeId,\n cmd,\n width,\n height,\n placeholder,\n uploadOptions,\n help,\n maskClosable,\n }: ChatPanelComponentProps,\n ref: React.Ref<ChatPanelRef>\n) {\n const modalRef = useRef<Modal>(null);\n const inputRef = useRef<ChatInput>(null);\n\n const [submitDisabled, setSubmitDisabled] = useState(false);\n\n const [conversationId, setConversationId] = useState<string | null>(null);\n const [initialRequest, setInitialRequest] = useState<RequestStore | null>(\n null\n );\n\n const { conversation, tasks, errors, humanInputRef } = useConversationDetail(\n conversationId,\n initialRequest\n );\n const conversationAvailable = !!conversation;\n const conversationState = conversation?.state;\n const conversationDone = DONE_STATES.includes(conversationState!);\n const canChat =\n !conversationId ||\n conversationDone ||\n conversationState === \"input-required\";\n\n const { messages } = useConversationStream(\n conversationAvailable,\n conversationState,\n tasks,\n errors\n );\n\n const humanInput = useCallback(\n (input: string | null, action?: string, extra?: ExtraChatPayload) => {\n humanInputRef.current?.(input, action, extra);\n },\n [humanInputRef]\n );\n\n const [depsReady, setDepsReady] = useState(false);\n useEffect(() => {\n let ignore = false;\n Promise.race([\n preloadHighlighter(\"light-plus\"),\n // Wait at most 5s\n new Promise((resolve) => setTimeout(resolve, 5000)),\n ]).finally(() => {\n if (!ignore) {\n setDepsReady(true);\n }\n });\n return () => {\n ignore = true;\n };\n }, []);\n\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const scrollContentRef = useRef<HTMLDivElement>(null);\n\n const { scrollable, scrollToBottom } = useAutoScroll(\n conversationAvailable && depsReady,\n scrollContainerRef,\n scrollContentRef\n );\n\n const handleChatSubmit = useCallback(\n async (payload: ChatPayload) => {\n if (conversationId) {\n const { content, ...extra } = payload;\n // For follow-up messages, do not pass aiEmployeeId and cmd again,\n // unless passed explicitly.\n humanInput(content, undefined, extra);\n return;\n }\n setSubmitDisabled(true);\n try {\n const res = await http.post<{\n data: { conversationId: string };\n }>(\n \"api/gateway/logic.llm.aiops_service/api/v1/elevo/conversations\",\n {}\n );\n const conversationId = res.data.conversationId;\n setConversationId(conversationId);\n setInitialRequest({\n ...payload,\n ...(aiEmployeeId ? { aiEmployeeId } : null),\n ...(cmd ? { cmd } : null),\n conversationId: conversationId,\n });\n } catch (e) {\n handleHttpError(e);\n } finally {\n setSubmitDisabled(false);\n }\n },\n [aiEmployeeId, cmd, conversationId, humanInput]\n );\n\n const [activeFile, setActiveFile] = useState<FileInfo | null>(null);\n const [activeImages, setActiveImages] = useState<ActiveImages | null>(null);\n\n const taskContextValue = useMemo(\n () =>\n ({\n conversationState,\n setActiveFile,\n setActiveImages,\n humanInput,\n }) as TaskContextValue,\n [conversationState, humanInput]\n );\n\n useImperativeHandle(\n ref,\n () => ({\n open: () => {\n modalRef.current?.open();\n },\n close: () => {\n modalRef.current?.close();\n },\n setInputValue: (content: string) => {\n inputRef.current?.setValue(content);\n },\n send: (payload: ChatPayload) => {\n handleChatSubmit(payload);\n },\n showFile: (file: FileInfo) => {\n setActiveFile(file);\n },\n }),\n [handleChatSubmit]\n );\n\n const earlyFinished =\n conversation?.finished && !NON_WORKING_STATES.includes(conversationState!);\n\n return (\n <TaskContext.Provider value={taskContextValue}>\n <WrappedModal\n modalTitle={panelTitle}\n width={width}\n height={height}\n themeVariant=\"elevo\"\n maskClosable={maskClosable}\n noFooter\n headerBordered\n fullscreenButton\n background={`fixed url(${backgroundImage}) center center / cover no-repeat`}\n onOpen={() => {\n setTimeout(() => {\n inputRef.current?.focus();\n }, 100);\n }}\n ref={modalRef}\n >\n <div className={styles.panel}>\n {!conversationId ? (\n <div className={styles.main}>\n {help ? (\n <ReactUseMultipleBricks useBrick={help.useBrick} />\n ) : null}\n </div>\n ) : conversationAvailable && depsReady ? (\n <div className={styles.main}>\n <div className={styles.chat} ref={scrollContainerRef}>\n <div className={styles.messages} ref={scrollContentRef}>\n {messages.map((msg, index, list) => (\n <div className={styles.message} key={index}>\n {msg.role === \"user\" ? (\n <UserMessage content={msg.content} files={msg.files} />\n ) : (\n <AssistantMessage\n chunks={msg.chunks}\n scopeState={conversation.state}\n isLatest={index === list.length - 1 && !earlyFinished}\n finished={conversation.finished}\n />\n )}\n </div>\n ))}\n {earlyFinished && (\n <div className={styles.message}>\n <AssistantMessage earlyFinished />\n </div>\n )}\n </div>\n </div>\n <button\n className={`${scrollStyles[\"scroll-down\"]} ${floatingStyles[\"floating-button\"]}`}\n style={{ bottom: \"30px\" }}\n hidden={!scrollable}\n onClick={scrollToBottom}\n >\n <WrappedIcon lib=\"antd\" icon=\"down\" />\n </button>\n </div>\n ) : (\n <div className={styles[\"loading-icon\"]}>\n <WrappedIcon\n lib=\"antd\"\n theme=\"outlined\"\n icon=\"loading-3-quarters\"\n spinning\n />\n </div>\n )}\n <div className={styles.input}>\n <WrappedChatInput\n ref={inputRef}\n placeholder={placeholder}\n suggestionsPlacement=\"top\"\n submitDisabled={submitDisabled || !canChat}\n supportsTerminate\n uploadOptions={uploadOptions}\n onChatSubmit={(e) => handleChatSubmit(e.detail)}\n />\n </div>\n </div>\n </WrappedModal>\n {activeFile && <FilePreview file={activeFile} fromModal />}\n {activeImages && <ImagesPreview images={activeImages} fromModal />}\n </TaskContext.Provider>\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.panel--ukaGUcR2{display:flex;flex-direction:column;min-height:300px;height:100%}.main--K5R8dLH9{position:relative;flex:1;min-height:0}.chat--Drl2ThnZ{padding:0 0 20px;height:100%;overflow-y:auto}.messages--Bhaarj69{width:100%;margin:0 auto}.message--TP5bdFpZ + .message--TP5bdFpZ{margin-top:40px}.loading-icon--BjI0pCV1{flex:1;display:flex;align-items:center;justify-content:center;font-size:48px;color:#fff}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"panel\": `panel--ukaGUcR2`,\n\t\"main\": `main--K5R8dLH9`,\n\t\"chat\": `chat--Drl2ThnZ`,\n\t\"messages\": `messages--Bhaarj69`,\n\t\"message\": `message--TP5bdFpZ`,\n\t\"loading-icon\": `loading-icon--BjI0pCV1`\n};\nexport default ___CSS_LOADER_EXPORT___;\n"],"names":["options","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","locals","undefined","WrappedModal","wrapBrick","onClose","onConfirm","onCancel","onOpen","defineElement","property","method","createDecorators","ChatPanelComponent","forwardRef","LegacyChatPanelComponent","_ChatPanel","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_ref","ChatPanel","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","_initProto","_init_panelTitle","_init_extra_panelTitle","_init_aiEmployeeId","_init_extra_aiEmployeeId","_init_cmd","_init_extra_cmd","_init_width","_init_extra_width","_init_height","_init_extra_height","_init_placeholder","_init_extra_placeholder","_init_uploadOptions","_init_extra_uploadOptions","_init_help","_init_extra_help","_init_maskClosable","_init_extra_maskClosable","createRef","panelTitle","_classPrivateFieldGet","v","_classPrivateFieldSet","aiEmployeeId","cmd","width","height","placeholder","uploadOptions","help","maskClosable","open","_classPrivateFieldGet2","this","current","close","_classPrivateFieldGet3","setInputValue","content","_classPrivateFieldGet4","send","payload","_classPrivateFieldGet5","showFile","file","_classPrivateFieldGet6","render","React","ref","_ref2","modalRef","useRef","inputRef","submitDisabled","setSubmitDisabled","useState","conversationId","setConversationId","initialRequest","setInitialRequest","conversation","tasks","errors","humanInputRef","useConversationDetail","conversationAvailable","conversationState","state","conversationDone","DONE_STATES","includes","canChat","messages","useConversationStream","humanInput","useCallback","input","action","extra","_humanInputRef$curren","call","depsReady","setDepsReady","useEffect","ignore","Promise","race","preloadHighlighter","resolve","setTimeout","finally","scrollContainerRef","scrollContentRef","scrollable","scrollToBottom","useAutoScroll","handleChatSubmit","async","http","post","data","e","handleHttpError","activeFile","setActiveFile","activeImages","setActiveImages","taskContextValue","useMemo","useImperativeHandle","_modalRef$current","_modalRef$current2","_inputRef$current","setValue","earlyFinished","finished","NON_WORKING_STATES","TaskContext","Provider","value","modalTitle","themeVariant","noFooter","headerBordered","fullscreenButton","background","backgroundImage","_inputRef$current2","focus","className","styles","panel","main","chat","map","msg","index","list","message","key","role","UserMessage","files","AssistantMessage","chunks","scopeState","isLatest","length","scrollStyles","floatingStyles","style","bottom","hidden","onClick","WrappedIcon","lib","icon","theme","spinning","ReactUseMultipleBricks","useBrick","WrappedChatInput","suggestionsPlacement","supportsTerminate","onChatSubmit","detail","FilePreview","fromModal","ImagesPreview","images","_ChatPanel2","c","_initClass","_applyDecs","shadowOptions","attribute","type","Boolean","___CSS_LOADER_EXPORT___","push","module","id"],"sourceRoot":""}
|