@next-bricks/ai-portal 0.64.3 → 0.64.5
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 +27 -27
- package/dist/chunks/3840.6080d56e.js +3 -0
- package/dist/chunks/3840.6080d56e.js.map +1 -0
- package/dist/chunks/4208.90f96600.js +2 -0
- package/dist/chunks/4208.90f96600.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/{main.88466dc4.js → main.792f3e2b.js} +2 -2
- package/dist/chunks/{main.88466dc4.js.map → main.792f3e2b.js.map} +1 -1
- package/dist/examples.json +17 -17
- package/dist/{index.802fcd04.js → index.ae9bb094.js} +2 -2
- package/dist/{index.802fcd04.js.map → index.ae9bb094.js.map} +1 -1
- package/dist/manifest.json +146 -146
- package/dist/types.json +370 -370
- package/package.json +2 -2
- package/dist/chunks/2028.81962baa.js +0 -3
- package/dist/chunks/2028.81962baa.js.map +0 -1
- package/dist/chunks/4208.e57d22a2.js +0 -2
- package/dist/chunks/4208.e57d22a2.js.map +0 -1
- package/dist/chunks/9271.24992b40.js.map +0 -1
- /package/dist/chunks/{2028.81962baa.js.LICENSE.txt → 3840.6080d56e.js.LICENSE.txt} +0 -0
|
@@ -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":""}
|
|
File without changes
|