@next-bricks/ai-portal 0.58.1 → 0.58.3
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 +36 -32
- package/dist/chunks/1488.d2c97a97.js +2 -0
- package/dist/chunks/1488.d2c97a97.js.map +1 -0
- package/dist/chunks/151.a5affad6.js +2 -0
- package/dist/chunks/151.a5affad6.js.map +1 -0
- package/dist/chunks/2232.fa4338ad.js +2 -0
- package/dist/chunks/2232.fa4338ad.js.map +1 -0
- package/dist/chunks/2324.c7c2427a.js +2 -0
- package/dist/chunks/2324.c7c2427a.js.map +1 -0
- package/dist/chunks/7238.9abe2a64.js +3 -0
- package/dist/chunks/{3848.01a4987f.js.LICENSE.txt → 7238.9abe2a64.js.LICENSE.txt} +2 -0
- package/dist/chunks/7238.9abe2a64.js.map +1 -0
- package/dist/chunks/7586.b406d4bf.js +2 -0
- package/dist/chunks/7586.b406d4bf.js.map +1 -0
- package/dist/chunks/9496.9bf2d483.js +2 -0
- package/dist/chunks/9496.9bf2d483.js.map +1 -0
- package/dist/chunks/chat-box.041da849.js +2 -0
- package/dist/chunks/chat-box.041da849.js.map +1 -0
- package/dist/chunks/chat-input.2c5e645b.js +2 -0
- package/dist/chunks/chat-input.2c5e645b.js.map +1 -0
- package/dist/chunks/chat-stream.6ca6e5c4.js +2 -0
- package/dist/chunks/chat-stream.6ca6e5c4.js.map +1 -0
- package/dist/chunks/cruise-canvas.12cab553.js +2 -0
- package/dist/chunks/cruise-canvas.12cab553.js.map +1 -0
- package/dist/chunks/{main.2d14a300.js → main.17b51dc3.js} +2 -2
- package/dist/chunks/{main.2d14a300.js.map → main.17b51dc3.js.map} +1 -1
- package/dist/chunks/notice-dropdown.37b8ffb2.js.map +1 -1
- package/dist/examples.json +16 -16
- package/dist/{index.11c928b3.js → index.fd3d8371.js} +2 -2
- package/dist/{index.11c928b3.js.map → index.fd3d8371.js.map} +1 -1
- package/dist/manifest.json +342 -322
- package/dist/types.json +1701 -1588
- package/dist-types/chat-stream/ChatStream.d.ts +2 -1
- package/dist-types/chat-stream/UserMessage/UserMessage.d.ts +2 -1
- package/dist-types/chat-stream/index.d.ts +5 -1
- package/dist-types/chat-stream/interfaces.d.ts +1 -0
- package/dist-types/cruise-canvas/CruiseCanvas.d.ts +1 -1
- package/dist-types/cruise-canvas/NodeRequirement/NodeRequirement.d.ts +2 -1
- package/dist-types/cruise-canvas/index.d.ts +7 -0
- package/dist-types/cruise-canvas/interfaces.d.ts +1 -0
- package/dist-types/notice-dropdown/index.d.ts +1 -12
- package/dist-types/shared/FileUpload/UploadButton.d.ts +1 -3
- package/dist-types/shared/ReadableCommand/ReadableCommand.d.ts +3 -2
- package/dist-types/shared/bricks.d.ts +10 -0
- package/dist-types/shared/fetchEmployee.d.ts +3 -0
- package/dist-types/shared/fetchEmployee.spec.d.ts +1 -0
- package/dist-types/shared/interfaces.d.ts +7 -0
- package/dist-types/shared/useFilesUploading.d.ts +5 -3
- package/package.json +2 -2
- package/dist/chunks/1488.46c471c4.js +0 -2
- package/dist/chunks/1488.46c471c4.js.map +0 -1
- package/dist/chunks/151.b87bccc0.js +0 -2
- package/dist/chunks/151.b87bccc0.js.map +0 -1
- package/dist/chunks/2232.05ad07e2.js +0 -2
- package/dist/chunks/2232.05ad07e2.js.map +0 -1
- package/dist/chunks/3848.01a4987f.js +0 -3
- package/dist/chunks/3848.01a4987f.js.map +0 -1
- package/dist/chunks/4002.68156a0e.js +0 -3
- package/dist/chunks/4002.68156a0e.js.LICENSE.txt +0 -1
- package/dist/chunks/4002.68156a0e.js.map +0 -1
- package/dist/chunks/7041.ff8d9ead.js +0 -2
- package/dist/chunks/7041.ff8d9ead.js.map +0 -1
- package/dist/chunks/9496.08074e2b.js +0 -2
- package/dist/chunks/9496.08074e2b.js.map +0 -1
- package/dist/chunks/chat-box.1b2a4a02.js +0 -2
- package/dist/chunks/chat-box.1b2a4a02.js.map +0 -1
- package/dist/chunks/chat-input.3ca07b82.js +0 -2
- package/dist/chunks/chat-input.3ca07b82.js.map +0 -1
- package/dist/chunks/chat-stream.a7c4f58d.js +0 -2
- package/dist/chunks/chat-stream.a7c4f58d.js.map +0 -1
- package/dist/chunks/cruise-canvas.b444c4ca.js +0 -2
- package/dist/chunks/cruise-canvas.b444c4ca.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunks/2324.c7c2427a.js","mappings":"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","sources":["webpack:///./src/shared/FileUpload/i18n.ts","webpack:///./src/shared/FileUpload/GlobalDragOverlay.module.css?40e0","webpack:///./src/shared/FileUpload/GlobalDragOverlay.tsx","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/shared/FileUpload/acceptFiles.ts","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}\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","\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","// 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 { acceptFiles } from \"./FileUpload/acceptFiles\";\n// import { getNextUid } from \"./FileUpload/UploadButton\";\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 accept = options?.accept;\n const maxFiles = options?.maxFiles;\n const dragTips = options?.dragTips;\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: File[]) => {\n setFiles((prev) => {\n const list = [\n ...(prev ?? []),\n ...newFiles.map<FileItem>((file) => ({\n uid: getNextUid(),\n file,\n status: \"ready\",\n })),\n ];\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 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 if (accept) {\n const allFilesAccepted = acceptFiles(accept, files);\n if (!allFilesAccepted) {\n handleHttpError(dragTips!);\n return;\n }\n }\n appendFiles(files);\n }\n },\n [enabled, accept, dragTips, 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: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 { 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","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","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","zh","options","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","locals","undefined","GlobalDragOverlay","_ref","disabled","accept","dragTips","onFilesDropped","isDragging","setIsDragging","useState","dragCounterRef","useRef","useEffect","current","handleDragEnter","e","_e$dataTransfer","preventDefault","stopPropagation","target","composedPath","HTMLElement","tagName","Array","from","dataTransfer","items","some","item","kind","handleDragLeave","handleDragOver","handleDrop","files","length","acceptFiles","handleHttpError","window","addEventListener","removeEventListener","createPortal","React","className","styles","overlay","src","dragImage","width","height","title","description","document","body","___CSS_LOADER_EXPORT___","push","module","id","WrappedIcon","wrapBrick","UploadedFiles","maxFiles","onRemove","onAdd","showAsImage","every","file","type","startsWith","classNames","onClick","map","FileComponent","_extends","key","uid","lib","icon","_ref2","status","abortController","getFileTypeAndIcon","name","size","formatFileSize","isImage","image","setImage","url","URL","createObjectURL","revokeObjectURL","buttonRemove","theme","failed","spinning","uploading","useFilesUploading","enabled","setFiles","hasFiles","forEach","async","fileItem","AbortController","prevFiles","formData","FormData","append","response","http","request","method","signal","fileInfo","data","error","allFilesDone","setAllFilesDone","fileInfos","setFileInfos","initialRef","appendFiles","useCallback","newFiles","prev","list","slice","resetFiles","removeFile","filter","exceeded","paste","fileList","clipboardData","toString","WrappedIconButton","ICON_UPLOAD","UploadButton","forwardRef","LegacyUploadButton","ref","onChange","inputRef","useImperativeHandle","requestUpload","_inputRef$current","click","multiple","hidden","value","variant","tooltip","_inputRef$current2","acceptedTypes","split","trim","mimeType","toLowerCase","endsWith","baseType","HIDDEN_STYLE","SIZING_STYLE","getMirroredStyle","element","uiTextNodeStyle","getComputedStyle","getPropertyValue","join","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":""}
|