@next-bricks/ai-portal 0.58.0 → 0.58.2

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.
Files changed (40) hide show
  1. package/dist/bricks.json +33 -33
  2. package/dist/chunks/1488.7acd87b5.js +2 -0
  3. package/dist/chunks/1488.7acd87b5.js.map +1 -0
  4. package/dist/chunks/2232.8b3d46e2.js +2 -0
  5. package/dist/chunks/2232.8b3d46e2.js.map +1 -0
  6. package/dist/chunks/{7041.d7408449.js → 7041.ff8d9ead.js} +2 -2
  7. package/dist/chunks/{7041.d7408449.js.map → 7041.ff8d9ead.js.map} +1 -1
  8. package/dist/chunks/7238.9abe2a64.js +3 -0
  9. package/dist/chunks/{3848.01a4987f.js.LICENSE.txt → 7238.9abe2a64.js.LICENSE.txt} +2 -0
  10. package/dist/chunks/7238.9abe2a64.js.map +1 -0
  11. package/dist/chunks/7586.b406d4bf.js +2 -0
  12. package/dist/chunks/7586.b406d4bf.js.map +1 -0
  13. package/dist/chunks/9496.9be62b7c.js +2 -0
  14. package/dist/chunks/9496.9be62b7c.js.map +1 -0
  15. package/dist/chunks/{main.703a0465.js → main.f26590db.js} +2 -2
  16. package/dist/chunks/{main.703a0465.js.map → main.f26590db.js.map} +1 -1
  17. package/dist/examples.json +23 -23
  18. package/dist/{index.7d751c21.js → index.734b36bb.js} +2 -2
  19. package/dist/{index.7d751c21.js.map → index.734b36bb.js.map} +1 -1
  20. package/dist/manifest.json +250 -250
  21. package/dist/types.json +1162 -1162
  22. package/dist-types/chat-stream/UserMessage/UserMessage.d.ts +2 -1
  23. package/dist-types/chat-stream/interfaces.d.ts +1 -0
  24. package/dist-types/cruise-canvas/NodeRequirement/NodeRequirement.d.ts +2 -1
  25. package/dist-types/cruise-canvas/interfaces.d.ts +1 -0
  26. package/dist-types/shared/ReadableCommand/ReadableCommand.d.ts +3 -2
  27. package/dist-types/shared/fetchEmployee.d.ts +3 -0
  28. package/dist-types/shared/fetchEmployee.spec.d.ts +1 -0
  29. package/package.json +2 -2
  30. package/dist/chunks/1488.89557180.js +0 -2
  31. package/dist/chunks/1488.89557180.js.map +0 -1
  32. package/dist/chunks/2232.75f1ab0f.js +0 -2
  33. package/dist/chunks/2232.75f1ab0f.js.map +0 -1
  34. package/dist/chunks/3848.01a4987f.js +0 -3
  35. package/dist/chunks/3848.01a4987f.js.map +0 -1
  36. package/dist/chunks/4002.68156a0e.js +0 -3
  37. package/dist/chunks/4002.68156a0e.js.LICENSE.txt +0 -1
  38. package/dist/chunks/4002.68156a0e.js.map +0 -1
  39. package/dist/chunks/9496.08074e2b.js +0 -2
  40. package/dist/chunks/9496.08074e2b.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"chunks/7041.d7408449.js","mappings":"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","sources":["webpack:///./src/shared/FileUpload/i18n.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/shared/FileUpload/GlobalDragOverlay.module.css?40e0","webpack:///./src/shared/FileUpload/GlobalDragOverlay.tsx","webpack:///./src/shared/FileUpload/acceptFiles.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}\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};\n\nconst zh: Locale = {\n UPLOAD_FILES: \"上传文件\",\n UPLOADING: \"上传中...\",\n UPLOAD_FAILED: \"上传失败\",\n DROP_FILES_HERE: \"在此处拖放文件\",\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","// 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 className={classNames(\"file\", { failed: status === \"failed\" })}>\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 } from \"./interfaces\";\n\nexport function useFilesUploading(maxFiles?: number) {\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\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: FileItem[] | undefined) => {\n setFiles((prev) => {\n if (!newFiles) {\n return prev;\n }\n const list = [...(prev ?? []), ...newFiles];\n if (maxFiles && list.length > maxFiles) {\n return list.slice(0, maxFiles);\n }\n return list;\n });\n },\n [maxFiles]\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 return {\n files,\n resetFiles,\n appendFiles,\n removeFile,\n hasFiles,\n allFilesDone,\n fileInfos,\n exceeded,\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:8px;display:flex;width:200px;height:60px;align-items:center;padding:0 8px;position:relative}.file-content{min-width:0;flex:1}.file-icon{margin:0 11px 0 6px}.file-image{margin-right:8px;object-fit:cover;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:8px;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:8px}.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:8px;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 type { FileItem } from \"./interfaces\";\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\nlet uid = 0;\n\nexport function getNextUid() {\n return uid++;\n}\n\nexport interface UploadButtonProps {\n accept?: string;\n disabled?: boolean;\n onChange?: (files: FileItem[] | undefined) => 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 onChange?.(\n files\n ? Array.from(files).map((file) => ({\n uid: getNextUid(),\n file,\n status: \"ready\",\n }))\n : undefined\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","\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 { handleHttpError } from \"@next-core/runtime\";\nimport dragImage from \"./drag-file@2x.png\";\nimport { K, t } from \"./i18n\";\nimport styles from \"./GlobalDragOverlay.module.css\";\nimport { acceptFiles } from \"./acceptFiles\";\n\nexport interface GlobalDragOverlayProps {\n disabled?: boolean;\n accept?: string;\n dragTips?: string;\n onFilesDropped?: (files: File[]) => void;\n}\n\nexport default function GlobalDragOverlay({\n disabled,\n accept,\n dragTips,\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 if (accept) {\n const allFilesAccepted = acceptFiles(accept, files);\n if (!allFilesAccepted) {\n handleHttpError(dragTips);\n return;\n }\n }\n onFilesDropped?.(files);\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 }, [accept, disabled, dragTips, 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}>{dragTips}</div>\n </div>,\n document.body\n );\n}\n","export function acceptFiles(accept: string, files: File[]) {\n const acceptedTypes = accept.split(\",\").map((type) => type.trim());\n const allFilesAccepted = files.every((file) => {\n const mimeType = file.type;\n return 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 });\n return allFilesAccepted;\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","zh","___CSS_LOADER_EXPORT___","push","module","id","locals","WrappedIcon","wrapBrick","UploadedFiles","_ref","files","maxFiles","className","onRemove","onAdd","showAsImage","every","file","type","startsWith","React","classNames","onClick","e","stopPropagation","map","FileComponent","_extends","key","uid","length","lib","icon","_ref2","status","abortController","getFileTypeAndIcon","name","size","formatFileSize","isImage","image","setImage","useState","useEffect","url","URL","createObjectURL","revokeObjectURL","undefined","buttonRemove","theme","failed","src","spinning","width","height","useFilesUploading","setFiles","hasFiles","forEach","async","fileItem","AbortController","prevFiles","item","formData","FormData","append","response","http","request","method","body","signal","fileInfo","data","error","handleHttpError","allFilesDone","setAllFilesDone","fileInfos","setFileInfos","initialRef","useRef","current","appendFiles","useCallback","newFiles","prev","list","slice","resetFiles","removeFile","filter","exceeded","toString","WrappedIconButton","ICON_UPLOAD","getNextUid","UploadButton","forwardRef","LegacyUploadButton","ref","accept","disabled","onChange","inputRef","useImperativeHandle","requestUpload","_inputRef$current","click","multiple","hidden","target","Array","from","value","variant","tooltip","_inputRef$current2","HIDDEN_STYLE","SIZING_STYLE","getMirroredStyle","element","uiTextNodeStyle","window","getComputedStyle","getPropertyValue","join","options","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","GlobalDragOverlay","dragTips","onFilesDropped","isDragging","setIsDragging","dragCounterRef","handleDragEnter","_e$dataTransfer","preventDefault","composedPath","HTMLElement","tagName","dataTransfer","items","some","kind","handleDragLeave","handleDragOver","handleDrop","allFilesAccepted","acceptedTypes","split","trim","mimeType","toLowerCase","endsWith","baseType","acceptFiles","addEventListener","removeEventListener","createPortal","styles","overlay","dragImage","title","description","document","hiddenTextarea","modKey","test","navigator","platform","TextareaAutoResize","LegacyTextareaAutoResize","autoResize","_autoResize","minRows","maxRows","borderSize","paddingSize","containerRef","propValue","style","submitWhen","desiredSelectionRef","onSubmit","onKeyDown","onCompositionStart","onCompositionEnd","props","setValue","textareaRef","autoStyle","setAutoStyle","focus","textarea","_textarea$value","valueLength","setSelectionRange","doAutoResize","uiTextNode","minHeight","maxHeight","overflowY","createElement","setAttribute","appendChild","placeholder","scrollHeight","singleRowHeight","parseFloat","Math","max","min","resize","calculateAutoSizeStyle","flushSync","compositionRef","handleCompositionStart","handleCompositionEnd","handleKeyDown","shiftKey","useLayoutEffect","desiredSelection","start","end","container","previousInlineSize","observer","ResizeObserver","entries","entry","currentInlineSize","contentBoxSize","inlineSize","contentRect","isInitial","requestAnimationFrame","observe","disconnect"],"sourceRoot":""}
1
+ {"version":3,"file":"chunks/7041.ff8d9ead.js","mappings":"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","sources":["webpack:///./src/shared/FileUpload/i18n.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/shared/FileUpload/GlobalDragOverlay.module.css?40e0","webpack:///./src/shared/FileUpload/GlobalDragOverlay.tsx","webpack:///./src/shared/FileUpload/acceptFiles.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}\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};\n\nconst zh: Locale = {\n UPLOAD_FILES: \"上传文件\",\n UPLOADING: \"上传中...\",\n UPLOAD_FAILED: \"上传失败\",\n DROP_FILES_HERE: \"在此处拖放文件\",\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","// 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 className={classNames(\"file\", { failed: status === \"failed\" })}>\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 } from \"./interfaces\";\n\nexport function useFilesUploading(maxFiles?: number) {\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\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: FileItem[] | undefined) => {\n setFiles((prev) => {\n if (!newFiles) {\n return prev;\n }\n const list = [...(prev ?? []), ...newFiles];\n if (maxFiles && list.length > maxFiles) {\n return list.slice(0, maxFiles);\n }\n return list;\n });\n },\n [maxFiles]\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 return {\n files,\n resetFiles,\n appendFiles,\n removeFile,\n hasFiles,\n allFilesDone,\n fileInfos,\n exceeded,\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-content{min-width:0;flex:1}.file-icon{margin:0 11px 0 6px}.file-image{margin-right:8px;object-fit:cover;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 type { FileItem } from \"./interfaces\";\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\nlet uid = 0;\n\nexport function getNextUid() {\n return uid++;\n}\n\nexport interface UploadButtonProps {\n accept?: string;\n disabled?: boolean;\n onChange?: (files: FileItem[] | undefined) => 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 onChange?.(\n files\n ? Array.from(files).map((file) => ({\n uid: getNextUid(),\n file,\n status: \"ready\",\n }))\n : undefined\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","\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 { handleHttpError } from \"@next-core/runtime\";\nimport dragImage from \"./drag-file@2x.png\";\nimport { K, t } from \"./i18n\";\nimport styles from \"./GlobalDragOverlay.module.css\";\nimport { acceptFiles } from \"./acceptFiles\";\n\nexport interface GlobalDragOverlayProps {\n disabled?: boolean;\n accept?: string;\n dragTips?: string;\n onFilesDropped?: (files: File[]) => void;\n}\n\nexport default function GlobalDragOverlay({\n disabled,\n accept,\n dragTips,\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 if (accept) {\n const allFilesAccepted = acceptFiles(accept, files);\n if (!allFilesAccepted) {\n handleHttpError(dragTips);\n return;\n }\n }\n onFilesDropped?.(files);\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 }, [accept, disabled, dragTips, 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}>{dragTips}</div>\n </div>,\n document.body\n );\n}\n","export function acceptFiles(accept: string, files: File[]) {\n const acceptedTypes = accept.split(\",\").map((type) => type.trim());\n const allFilesAccepted = files.every((file) => {\n const mimeType = file.type;\n return 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 });\n return allFilesAccepted;\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","zh","___CSS_LOADER_EXPORT___","push","module","id","locals","WrappedIcon","wrapBrick","UploadedFiles","_ref","files","maxFiles","className","onRemove","onAdd","showAsImage","every","file","type","startsWith","React","classNames","onClick","e","stopPropagation","map","FileComponent","_extends","key","uid","length","lib","icon","_ref2","status","abortController","getFileTypeAndIcon","name","size","formatFileSize","isImage","image","setImage","useState","useEffect","url","URL","createObjectURL","revokeObjectURL","undefined","buttonRemove","theme","failed","src","spinning","width","height","useFilesUploading","setFiles","hasFiles","forEach","async","fileItem","AbortController","prevFiles","item","formData","FormData","append","response","http","request","method","body","signal","fileInfo","data","error","handleHttpError","allFilesDone","setAllFilesDone","fileInfos","setFileInfos","initialRef","useRef","current","appendFiles","useCallback","newFiles","prev","list","slice","resetFiles","removeFile","filter","exceeded","toString","WrappedIconButton","ICON_UPLOAD","getNextUid","UploadButton","forwardRef","LegacyUploadButton","ref","accept","disabled","onChange","inputRef","useImperativeHandle","requestUpload","_inputRef$current","click","multiple","hidden","target","Array","from","value","variant","tooltip","_inputRef$current2","HIDDEN_STYLE","SIZING_STYLE","getMirroredStyle","element","uiTextNodeStyle","window","getComputedStyle","getPropertyValue","join","options","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","GlobalDragOverlay","dragTips","onFilesDropped","isDragging","setIsDragging","dragCounterRef","handleDragEnter","_e$dataTransfer","preventDefault","composedPath","HTMLElement","tagName","dataTransfer","items","some","kind","handleDragLeave","handleDragOver","handleDrop","allFilesAccepted","acceptedTypes","split","trim","mimeType","toLowerCase","endsWith","baseType","acceptFiles","addEventListener","removeEventListener","createPortal","styles","overlay","dragImage","title","description","document","hiddenTextarea","modKey","test","navigator","platform","TextareaAutoResize","LegacyTextareaAutoResize","autoResize","_autoResize","minRows","maxRows","borderSize","paddingSize","containerRef","propValue","style","submitWhen","desiredSelectionRef","onSubmit","onKeyDown","onCompositionStart","onCompositionEnd","props","setValue","textareaRef","autoStyle","setAutoStyle","focus","textarea","_textarea$value","valueLength","setSelectionRange","doAutoResize","uiTextNode","minHeight","maxHeight","overflowY","createElement","setAttribute","appendChild","placeholder","scrollHeight","singleRowHeight","parseFloat","Math","max","min","resize","calculateAutoSizeStyle","flushSync","compositionRef","handleCompositionStart","handleCompositionEnd","handleKeyDown","shiftKey","useLayoutEffect","desiredSelection","start","end","container","previousInlineSize","observer","ResizeObserver","entries","entry","currentInlineSize","contentBoxSize","inlineSize","contentRect","isInitial","requestAnimationFrame","observe","disconnect"],"sourceRoot":""}