giime 0.6.39 → 0.6.41

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 (42) hide show
  1. package/dist/index.css +2 -2
  2. package/es/components/src/business/uploadPro/UploadPro.vue.d.ts +18 -0
  3. package/es/components/src/business/uploadPro/UploadPro.vue.mjs +1 -1
  4. package/es/components/src/business/uploadPro/UploadPro.vue2.mjs +4 -3
  5. package/es/components/src/business/uploadPro/UploadPro.vue2.mjs.map +1 -1
  6. package/es/components/src/business/uploadPro/index.d.ts +38 -0
  7. package/es/components/src/business/uploadPro/uploadPro.d.ts +10 -0
  8. package/es/components/src/business/uploadPro/uploadPro.mjs +10 -0
  9. package/es/components/src/business/uploadPro/uploadPro.mjs.map +1 -1
  10. package/es/components/src/composite/fileComponent/FileComponent.vue2.mjs +18 -27
  11. package/es/components/src/composite/fileComponent/FileComponent.vue2.mjs.map +1 -1
  12. package/es/components/src/plugins/confirmBox/index.d.ts +1 -1
  13. package/es/components/src/plugins/confirmBox/method.d.ts +1 -1
  14. package/es/components/src/plugins/confirmBox/method.mjs +3 -3
  15. package/es/components/src/plugins/confirmBox/method.mjs.map +1 -1
  16. package/es/giime/version.d.ts +1 -1
  17. package/es/giime/version.mjs +1 -1
  18. package/es/giime/version.mjs.map +1 -1
  19. package/es/index.css +2 -2
  20. package/es/utils/src/is.mjs +1 -1
  21. package/es/utils/src/is.mjs.map +1 -1
  22. package/lib/components/src/business/uploadPro/UploadPro.vue.d.ts +18 -0
  23. package/lib/components/src/business/uploadPro/UploadPro.vue.js +1 -1
  24. package/lib/components/src/business/uploadPro/UploadPro.vue2.js +4 -3
  25. package/lib/components/src/business/uploadPro/UploadPro.vue2.js.map +1 -1
  26. package/lib/components/src/business/uploadPro/index.d.ts +38 -0
  27. package/lib/components/src/business/uploadPro/uploadPro.d.ts +10 -0
  28. package/lib/components/src/business/uploadPro/uploadPro.js +10 -0
  29. package/lib/components/src/business/uploadPro/uploadPro.js.map +1 -1
  30. package/lib/components/src/composite/fileComponent/FileComponent.vue2.js +16 -25
  31. package/lib/components/src/composite/fileComponent/FileComponent.vue2.js.map +1 -1
  32. package/lib/components/src/plugins/confirmBox/index.d.ts +1 -1
  33. package/lib/components/src/plugins/confirmBox/method.d.ts +1 -1
  34. package/lib/components/src/plugins/confirmBox/method.js +3 -3
  35. package/lib/components/src/plugins/confirmBox/method.js.map +1 -1
  36. package/lib/giime/version.d.ts +1 -1
  37. package/lib/giime/version.js +1 -1
  38. package/lib/giime/version.js.map +1 -1
  39. package/lib/index.css +2 -2
  40. package/lib/utils/src/is.js +1 -1
  41. package/lib/utils/src/is.js.map +1 -1
  42. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"is.mjs","sources":["../../../../../packages/utils/src/is.ts"],"sourcesContent":["const toString = Object.prototype.toString;\nexport function getTag(value: any): string {\n if (value === null) {\n return '[object Null]';\n } else if (value === undefined) {\n return '[object Undefined]';\n }\n return toString.call(value);\n}\nexport function isObjectLike(value: any): boolean {\n return typeof value === 'object' && value !== null;\n}\nexport function isBoolean(value: any): value is boolean {\n return value === true || value === false || (isObjectLike(value) && getTag(value) === '[object Boolean]');\n}\n\nexport function isString(value: any): value is string {\n return typeof value === 'string' || (isObjectLike(value) && getTag(value) === '[object String]');\n}\n\nexport function isNumber(value: any): value is number {\n return typeof value === 'number' || (isObjectLike(value) && getTag(value) === '[object Number]');\n}\nexport function isSymbol(value: any): value is symbol {\n return typeof value === 'symbol' || (isObjectLike(value) && getTag(value) === '[object Symbol]');\n}\nexport function isDate(value: any): value is Date {\n return isObjectLike(value) && getTag(value) === '[object Date]';\n}\nexport const isFunction = (val: unknown): val is Function => typeof val === 'function';\n/**\n * 整数\n */\nexport function isInteger(val: any): val is number {\n return isNumber(val) && val % 1 === 0;\n}\n/**\n * 小数\n */\nexport function isDecimal(val: any): val is number {\n return isNumber(val) && val % 1 !== 0;\n}\n/**\n * 负数\n */\nexport function isNegative(val: any): val is number {\n return isNumber(val) && val < 0;\n}\n/**\n * 正数\n */\nexport function isPositive(val: any): val is number {\n return isNumber(val) && val > 0;\n}\n/**\n * 奇数\n */\nexport function isOdd(val: any): val is number {\n return isNumber(val) && val % 2 !== 0;\n}\n/**\n * 偶数\n */\nexport function isEven(val: any): val is number {\n return isNumber(val) && val % 2 === 0;\n}\n\nexport function isUndefined(val: any): val is undefined {\n return val === undefined;\n}\nexport function isNull(val: any): val is null {\n return val === null;\n}\nexport function isNil(val: any): val is null | undefined {\n return isUndefined(val) || isNull(val);\n}\n/**\n * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`,\n * `SyntaxError`, `TypeError`, or `URIError` object.\n */\nexport function isError(value: any): value is Error {\n if (!isObjectLike(value)) {\n return false;\n }\n const tag = getTag(value);\n return (\n tag === '[object Error]' ||\n tag === '[object DOMException]' ||\n (typeof value.message === 'string' && typeof value.name === 'string' && !isPlainObject(value))\n );\n}\nexport function isPlainObject(value: any): value is object {\n if (!isObjectLike(value) || getTag(value) !== '[object Object]') {\n return false;\n }\n if (Object.getPrototypeOf(value) === null) {\n return true;\n }\n let proto = value;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(value) === proto;\n}\n\nexport const isHttps = () => {\n return window.location.protocol.startsWith('https');\n};\nexport const isClient = typeof window !== 'undefined' && typeof document !== 'undefined';\n\nexport const isIOS = /* #__PURE__ */ getIsIOS();\n\nfunction getIsIOS() {\n return (\n isClient &&\n window?.navigator?.userAgent &&\n (/iP(?:ad|hone|od)/.test(window.navigator.userAgent) ||\n // The new iPad Pro Gen3 does not identify itself as iPad, but as Macintosh.\n // https://github.com/vueuse/vueuse/issues/3577\n (window?.navigator?.maxTouchPoints > 2 && /iPad|Macintosh/.test(window?.navigator.userAgent)))\n );\n}\n\n/**\n * 文件类型枚举\n */\nexport enum FileType {\n Video = 'Video',\n Image = 'Image',\n Pdf = 'Pdf',\n Word = 'Word',\n Excel = 'Excel',\n Ppt = 'Ppt',\n Text = 'Text',\n Psd = 'Psd',\n Zip = 'Zip',\n}\n\n/**\n * 不同文件类型的扩展名配置\n */\nexport const FILE_EXTENSIONS: Record<FileType, readonly string[]> = {\n [FileType.Video]: ['mp4', 'avi', 'rmvb', 'rm', 'wmv', 'mpg', 'mpeg', 'mov', 'mkv', 'flv'],\n [FileType.Image]: ['jpg', 'jpeg', 'png', 'gif', 'webp', 'svg', 'bmp'],\n [FileType.Pdf]: ['pdf'],\n [FileType.Word]: ['doc', 'docx'],\n [FileType.Excel]: ['xls', 'xlsx'],\n [FileType.Ppt]: ['ppt', 'pptx'],\n [FileType.Text]: ['txt'],\n [FileType.Psd]: ['psd'],\n [FileType.Zip]: ['zip', 'rar', '7z'],\n} as const;\n\n/**\n * 创建用于匹配文件扩展名的正则表达式\n * @param extensions 文件扩展名数组\n * @returns 用于匹配文件扩展名的正则表达式\n */\nconst createExtensionRegex = (extensions: readonly string[]): RegExp => {\n return new RegExp(`\\\\.(${extensions.join('|')})$`, 'i');\n};\n\n/**\n * 通用函数,用于检查URL是否匹配特定文件扩展名\n * @param url 要检查的文件URL或文件名\n * @param type 要检查的文件类型\n * @returns 布尔值,表示URL是否匹配该文件类型\n */\nconst isFileType = (url: string, type: FileType): boolean => {\n if (!isString(url)) return false;\n // 首先通过URL去除查询参数和哈希值\n const baseUrl = url.split('?')[0].split('#')[0];\n const regex = createExtensionRegex(FILE_EXTENSIONS[type]);\n return regex.test(baseUrl);\n};\n\n/**\n * @description 判断是否为视频\n * @param url 文件链接 或 文件名\n */\nexport const isVideoUrl = (url: string): boolean => isFileType(url, FileType.Video);\n\n/**\n * @description 判断是否为图片\n * @param url 文件链接 或 文件名\n */\nexport const isImageUrl = (url: string): boolean => isFileType(url, FileType.Image);\n\n/**\n * @description 判断是否为PDF\n * @param url 文件链接 或 文件名\n */\nexport const isPDF = (url: string): boolean => isFileType(url, FileType.Pdf);\n\n/**\n * @description 是否为Word文档\n * @param url 文件链接 或 文件名\n */\nexport const isWord = (url: string): boolean => isFileType(url, FileType.Word);\n\n/**\n * @description 是否为Excel文件\n * @param url 文件链接 或 文件名\n */\nexport const isExcel = (url: string): boolean => isFileType(url, FileType.Excel);\n\n/**\n * @description 是否为PPT文件\n * @param url 文件链接 或 文件名\n */\nexport const isPPT = (url: string): boolean => isFileType(url, FileType.Ppt);\n\n/**\n * @description 是否为文本文件\n * @param url 文件链接 或 文件名\n */\nexport const isText = (url: string): boolean => isFileType(url, FileType.Text);\n\n/**\n * @description 是否为PSD文件\n * @param url 文件链接 或 文件名\n */\nexport const isPSD = (url: string): boolean => isFileType(url, FileType.Psd);\n\n/**\n * @description 判断是否为压缩包\n * @param url 文件链接 或 文件名\n */\nexport const isZip = (url: string): boolean => isFileType(url, FileType.Zip);\n"],"names":["FileType"],"mappings":"AAAA,MAAM,QAAA,GAAW,OAAO,SAAU,CAAA,QAAA,CAAA;AAC3B,SAAS,OAAO,KAAoB,EAAA;AACzC,EAAA,IAAI,UAAU,IAAM,EAAA;AAClB,IAAO,OAAA,eAAA,CAAA;AAAA,GACT,MAAA,IAAW,UAAU,KAAW,CAAA,EAAA;AAC9B,IAAO,OAAA,oBAAA,CAAA;AAAA,GACT;AACA,EAAO,OAAA,QAAA,CAAS,KAAK,KAAK,CAAA,CAAA;AAC5B,CAAA;AACO,SAAS,aAAa,KAAqB,EAAA;AAChD,EAAO,OAAA,OAAO,KAAU,KAAA,QAAA,IAAY,KAAU,KAAA,IAAA,CAAA;AAChD,CAAA;AACO,SAAS,UAAU,KAA8B,EAAA;AACtD,EAAO,OAAA,KAAA,KAAU,QAAQ,KAAU,KAAA,KAAA,IAAU,aAAa,KAAK,CAAA,IAAK,MAAO,CAAA,KAAK,CAAM,KAAA,kBAAA,CAAA;AACxF,CAAA;AAEO,SAAS,SAAS,KAA6B,EAAA;AACpD,EAAO,OAAA,OAAO,UAAU,QAAa,IAAA,YAAA,CAAa,KAAK,CAAK,IAAA,MAAA,CAAO,KAAK,CAAM,KAAA,iBAAA,CAAA;AAChF,CAAA;AAEO,SAAS,SAAS,KAA6B,EAAA;AACpD,EAAO,OAAA,OAAO,UAAU,QAAa,IAAA,YAAA,CAAa,KAAK,CAAK,IAAA,MAAA,CAAO,KAAK,CAAM,KAAA,iBAAA,CAAA;AAChF,CAAA;AACO,SAAS,SAAS,KAA6B,EAAA;AACpD,EAAO,OAAA,OAAO,UAAU,QAAa,IAAA,YAAA,CAAa,KAAK,CAAK,IAAA,MAAA,CAAO,KAAK,CAAM,KAAA,iBAAA,CAAA;AAChF,CAAA;AACO,SAAS,OAAO,KAA2B,EAAA;AAChD,EAAA,OAAO,YAAa,CAAA,KAAK,CAAK,IAAA,MAAA,CAAO,KAAK,CAAM,KAAA,eAAA,CAAA;AAClD,CAAA;AACO,MAAM,UAAa,GAAA,CAAC,GAAkC,KAAA,OAAO,GAAQ,KAAA,WAAA;AAIrE,SAAS,UAAU,GAAyB,EAAA;AACjD,EAAA,OAAO,QAAS,CAAA,GAAG,CAAK,IAAA,GAAA,GAAM,CAAM,KAAA,CAAA,CAAA;AACtC,CAAA;AAIO,SAAS,UAAU,GAAyB,EAAA;AACjD,EAAA,OAAO,QAAS,CAAA,GAAG,CAAK,IAAA,GAAA,GAAM,CAAM,KAAA,CAAA,CAAA;AACtC,CAAA;AAIO,SAAS,WAAW,GAAyB,EAAA;AAClD,EAAO,OAAA,QAAA,CAAS,GAAG,CAAA,IAAK,GAAM,GAAA,CAAA,CAAA;AAChC,CAAA;AAIO,SAAS,WAAW,GAAyB,EAAA;AAClD,EAAO,OAAA,QAAA,CAAS,GAAG,CAAA,IAAK,GAAM,GAAA,CAAA,CAAA;AAChC,CAAA;AAIO,SAAS,MAAM,GAAyB,EAAA;AAC7C,EAAA,OAAO,QAAS,CAAA,GAAG,CAAK,IAAA,GAAA,GAAM,CAAM,KAAA,CAAA,CAAA;AACtC,CAAA;AAIO,SAAS,OAAO,GAAyB,EAAA;AAC9C,EAAA,OAAO,QAAS,CAAA,GAAG,CAAK,IAAA,GAAA,GAAM,CAAM,KAAA,CAAA,CAAA;AACtC,CAAA;AAEO,SAAS,YAAY,GAA4B,EAAA;AACtD,EAAA,OAAO,GAAQ,KAAA,KAAA,CAAA,CAAA;AACjB,CAAA;AACO,SAAS,OAAO,GAAuB,EAAA;AAC5C,EAAA,OAAO,GAAQ,KAAA,IAAA,CAAA;AACjB,CAAA;AACO,SAAS,MAAM,GAAmC,EAAA;AACvD,EAAA,OAAO,WAAY,CAAA,GAAG,CAAK,IAAA,MAAA,CAAO,GAAG,CAAA,CAAA;AACvC,CAAA;AAKO,SAAS,QAAQ,KAA4B,EAAA;AAClD,EAAI,IAAA,CAAC,YAAa,CAAA,KAAK,CAAG,EAAA;AACxB,IAAO,OAAA,KAAA,CAAA;AAAA,GACT;AACA,EAAM,MAAA,GAAA,GAAM,OAAO,KAAK,CAAA,CAAA;AACxB,EAAA,OACE,GAAQ,KAAA,gBAAA,IACR,GAAQ,KAAA,uBAAA,IACP,OAAO,KAAM,CAAA,OAAA,KAAY,QAAY,IAAA,OAAO,KAAM,CAAA,IAAA,KAAS,QAAY,IAAA,CAAC,cAAc,KAAK,CAAA,CAAA;AAEhG,CAAA;AACO,SAAS,cAAc,KAA6B,EAAA;AACzD,EAAA,IAAI,CAAC,YAAa,CAAA,KAAK,KAAK,MAAO,CAAA,KAAK,MAAM,iBAAmB,EAAA;AAC/D,IAAO,OAAA,KAAA,CAAA;AAAA,GACT;AACA,EAAA,IAAI,MAAO,CAAA,cAAA,CAAe,KAAK,CAAA,KAAM,IAAM,EAAA;AACzC,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AACA,EAAA,IAAI,KAAQ,GAAA,KAAA,CAAA;AACZ,EAAA,OAAO,MAAO,CAAA,cAAA,CAAe,KAAK,CAAA,KAAM,IAAM,EAAA;AAC5C,IAAQ,KAAA,GAAA,MAAA,CAAO,eAAe,KAAK,CAAA,CAAA;AAAA,GACrC;AACA,EAAO,OAAA,MAAA,CAAO,cAAe,CAAA,KAAK,CAAM,KAAA,KAAA,CAAA;AAC1C,CAAA;AAEO,MAAM,UAAU,MAAM;AAC3B,EAAA,OAAO,MAAO,CAAA,QAAA,CAAS,QAAS,CAAA,UAAA,CAAW,OAAO,CAAA,CAAA;AACpD,EAAA;AACO,MAAM,QAAW,GAAA,OAAO,MAAW,KAAA,WAAA,IAAe,OAAO,QAAa,KAAA,YAAA;AAEtE,MAAM,wBAAiC,QAAA,GAAA;AAE9C,SAAS,QAAW,GAAA;AAClB,EACE,OAAA,QAAA,IACA,QAAQ,SAAW,EAAA,SAAA,KAClB,mBAAmB,IAAK,CAAA,MAAA,CAAO,UAAU,SAAS,CAAA;AAAA;AAAA,EAGhD,MAAA,EAAQ,WAAW,cAAiB,GAAA,CAAA,IAAK,iBAAiB,IAAK,CAAA,MAAA,EAAQ,UAAU,SAAS,CAAA,CAAA,CAAA;AAEjG,CAAA;AAKY,IAAA,QAAA,qBAAAA,SAAL,KAAA;AACL,EAAAA,UAAA,OAAQ,CAAA,GAAA,OAAA,CAAA;AACR,EAAAA,UAAA,OAAQ,CAAA,GAAA,OAAA,CAAA;AACR,EAAAA,UAAA,KAAM,CAAA,GAAA,KAAA,CAAA;AACN,EAAAA,UAAA,MAAO,CAAA,GAAA,MAAA,CAAA;AACP,EAAAA,UAAA,OAAQ,CAAA,GAAA,OAAA,CAAA;AACR,EAAAA,UAAA,KAAM,CAAA,GAAA,KAAA,CAAA;AACN,EAAAA,UAAA,MAAO,CAAA,GAAA,MAAA,CAAA;AACP,EAAAA,UAAA,KAAM,CAAA,GAAA,KAAA,CAAA;AACN,EAAAA,UAAA,KAAM,CAAA,GAAA,KAAA,CAAA;AATI,EAAAA,OAAAA,SAAAA,CAAAA;AAAA,CAAA,EAAA,QAAA,IAAA,EAAA,EAAA;AAeL,MAAM,eAAuD,GAAA;AAAA,EAClE,CAAC,OAAA,eAAiB,CAAC,KAAO,EAAA,KAAA,EAAO,MAAQ,EAAA,IAAA,EAAM,KAAO,EAAA,KAAA,EAAO,MAAQ,EAAA,KAAA,EAAO,OAAO,KAAK,CAAA;AAAA,EACxF,CAAC,OAAc,eAAG,CAAC,KAAA,EAAO,QAAQ,KAAO,EAAA,KAAA,EAAO,MAAQ,EAAA,KAAA,EAAO,KAAK,CAAA;AAAA,EACpE,CAAC,KAAA,aAAe,CAAC,KAAK,CAAA;AAAA,EACtB,CAAC,MAAA,cAAgB,CAAC,OAAO,MAAM,CAAA;AAAA,EAC/B,CAAC,OAAA,eAAiB,CAAC,OAAO,MAAM,CAAA;AAAA,EAChC,CAAC,KAAA,aAAe,CAAC,OAAO,MAAM,CAAA;AAAA,EAC9B,CAAC,MAAA,cAAgB,CAAC,KAAK,CAAA;AAAA,EACvB,CAAC,KAAA,aAAe,CAAC,KAAK,CAAA;AAAA,EACtB,CAAC,KAAY,aAAG,CAAC,KAAA,EAAO,OAAO,IAAI,CAAA;AACrC,EAAA;AAOA,MAAM,oBAAA,GAAuB,CAAC,UAA0C,KAAA;AACtE,EAAO,OAAA,IAAI,OAAO,CAAO,IAAA,EAAA,UAAA,CAAW,KAAK,GAAG,CAAC,MAAM,GAAG,CAAA,CAAA;AACxD,CAAA,CAAA;AAQA,MAAM,UAAA,GAAa,CAAC,GAAA,EAAa,IAA4B,KAAA;AAC3D,EAAI,IAAA,CAAC,SAAS,GAAG,CAAA;AAAG,IAAO,OAAA,KAAA,CAAA;AAE3B,EAAM,MAAA,OAAA,GAAU,GAAI,CAAA,KAAA,CAAM,GAAG,CAAA,CAAE,CAAC,CAAE,CAAA,KAAA,CAAM,GAAG,CAAA,CAAE,CAAC,CAAA,CAAA;AAC9C,EAAA,MAAM,KAAQ,GAAA,oBAAA,CAAqB,eAAgB,CAAA,IAAI,CAAC,CAAA,CAAA;AACxD,EAAO,OAAA,KAAA,CAAM,KAAK,OAAO,CAAA,CAAA;AAC3B,CAAA,CAAA;AAMO,MAAM,UAAa,GAAA,CAAC,GAAyB,KAAA,UAAA,CAAW,KAAK,OAAc,cAAA;AAM3E,MAAM,UAAa,GAAA,CAAC,GAAyB,KAAA,UAAA,CAAW,KAAK,OAAc,cAAA;AAM3E,MAAM,KAAQ,GAAA,CAAC,GAAyB,KAAA,UAAA,CAAW,KAAK,KAAY,YAAA;AAMpE,MAAM,MAAS,GAAA,CAAC,GAAyB,KAAA,UAAA,CAAW,KAAK,MAAa,aAAA;AAMtE,MAAM,OAAU,GAAA,CAAC,GAAyB,KAAA,UAAA,CAAW,KAAK,OAAc,cAAA;AAMxE,MAAM,KAAQ,GAAA,CAAC,GAAyB,KAAA,UAAA,CAAW,KAAK,KAAY,YAAA;AAMpE,MAAM,MAAS,GAAA,CAAC,GAAyB,KAAA,UAAA,CAAW,KAAK,MAAa,aAAA;AAMtE,MAAM,KAAQ,GAAA,CAAC,GAAyB,KAAA,UAAA,CAAW,KAAK,KAAY,YAAA;AAMpE,MAAM,KAAQ,GAAA,CAAC,GAAyB,KAAA,UAAA,CAAW,KAAK,KAAY;;;;"}
1
+ {"version":3,"file":"is.mjs","sources":["../../../../../packages/utils/src/is.ts"],"sourcesContent":["const toString = Object.prototype.toString;\nexport function getTag(value: any): string {\n if (value === null) {\n return '[object Null]';\n } else if (value === undefined) {\n return '[object Undefined]';\n }\n return toString.call(value);\n}\nexport function isObjectLike(value: any): boolean {\n return typeof value === 'object' && value !== null;\n}\nexport function isBoolean(value: any): value is boolean {\n return value === true || value === false || (isObjectLike(value) && getTag(value) === '[object Boolean]');\n}\n\nexport function isString(value: any): value is string {\n return typeof value === 'string' || (isObjectLike(value) && getTag(value) === '[object String]');\n}\n\nexport function isNumber(value: any): value is number {\n return typeof value === 'number' || (isObjectLike(value) && getTag(value) === '[object Number]');\n}\nexport function isSymbol(value: any): value is symbol {\n return typeof value === 'symbol' || (isObjectLike(value) && getTag(value) === '[object Symbol]');\n}\nexport function isDate(value: any): value is Date {\n return isObjectLike(value) && getTag(value) === '[object Date]';\n}\nexport const isFunction = (val: unknown): val is Function => typeof val === 'function';\n/**\n * 整数\n */\nexport function isInteger(val: any): val is number {\n return isNumber(val) && val % 1 === 0;\n}\n/**\n * 小数\n */\nexport function isDecimal(val: any): val is number {\n return isNumber(val) && val % 1 !== 0;\n}\n/**\n * 负数\n */\nexport function isNegative(val: any): val is number {\n return isNumber(val) && val < 0;\n}\n/**\n * 正数\n */\nexport function isPositive(val: any): val is number {\n return isNumber(val) && val > 0;\n}\n/**\n * 奇数\n */\nexport function isOdd(val: any): val is number {\n return isNumber(val) && val % 2 !== 0;\n}\n/**\n * 偶数\n */\nexport function isEven(val: any): val is number {\n return isNumber(val) && val % 2 === 0;\n}\n\nexport function isUndefined(val: any): val is undefined {\n return val === undefined;\n}\nexport function isNull(val: any): val is null {\n return val === null;\n}\nexport function isNil(val: any): val is null | undefined {\n return isUndefined(val) || isNull(val);\n}\n/**\n * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`,\n * `SyntaxError`, `TypeError`, or `URIError` object.\n */\nexport function isError(value: any): value is Error {\n if (!isObjectLike(value)) {\n return false;\n }\n const tag = getTag(value);\n return (\n tag === '[object Error]' ||\n tag === '[object DOMException]' ||\n (typeof value.message === 'string' && typeof value.name === 'string' && !isPlainObject(value))\n );\n}\nexport function isPlainObject(value: any): value is object {\n if (!isObjectLike(value) || getTag(value) !== '[object Object]') {\n return false;\n }\n if (Object.getPrototypeOf(value) === null) {\n return true;\n }\n let proto = value;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(value) === proto;\n}\n\nexport const isHttps = () => {\n return window.location.protocol.startsWith('https');\n};\nexport const isClient = typeof window !== 'undefined' && typeof document !== 'undefined';\n\nexport const isIOS = /* #__PURE__ */ getIsIOS();\n\nfunction getIsIOS() {\n return (\n isClient &&\n window?.navigator?.userAgent &&\n (/iP(?:ad|hone|od)/.test(window.navigator.userAgent) ||\n // The new iPad Pro Gen3 does not identify itself as iPad, but as Macintosh.\n // https://github.com/vueuse/vueuse/issues/3577\n (window?.navigator?.maxTouchPoints > 2 && /iPad|Macintosh/.test(window?.navigator.userAgent)))\n );\n}\n\n/**\n * 文件类型枚举\n */\nexport enum FileType {\n Video = 'Video',\n Image = 'Image',\n Pdf = 'Pdf',\n Word = 'Word',\n Excel = 'Excel',\n Ppt = 'Ppt',\n Text = 'Text',\n Psd = 'Psd',\n Zip = 'Zip',\n}\n\n/**\n * 不同文件类型的扩展名配置\n */\nexport const FILE_EXTENSIONS: Record<FileType, readonly string[]> = {\n [FileType.Video]: ['mp4', 'avi', 'rmvb', 'rm', 'wmv', 'mpg', 'mpeg', 'mov', 'mkv', 'flv'],\n [FileType.Image]: ['jpg', 'jpeg', 'png', 'gif', 'webp', 'svg', 'bmp'],\n [FileType.Pdf]: ['pdf'],\n [FileType.Word]: ['doc', 'docx'],\n [FileType.Excel]: ['xls', 'xlsx'],\n [FileType.Ppt]: ['ppt', 'pptx'],\n [FileType.Text]: ['txt'],\n [FileType.Psd]: ['psd'],\n [FileType.Zip]: ['zip', 'rar', '7z'],\n} as const;\n\n/**\n * 创建用于匹配文件扩展名的正则表达式\n * @param extensions 文件扩展名数组\n * @returns 用于匹配文件扩展名的正则表达式\n */\nconst createExtensionRegex = (extensions: readonly string[]): RegExp => {\n return new RegExp(`\\\\.(${extensions.join('|')})$`, 'i');\n};\n\n/**\n * 通用函数,用于检查URL是否匹配特定文件扩展名\n * @param url 要检查的文件URL或文件名\n * @param type 要检查的文件类型\n * @returns 布尔值,表示URL是否匹配该文件类型\n */\nconst isFileType = (url: string, type: FileType): boolean => {\n if (!isString(url)) return false;\n // 首先通过URL去除查询参数和哈希值\n const baseUrl = url.split('?')[0];\n const regex = createExtensionRegex(FILE_EXTENSIONS[type]);\n return regex.test(baseUrl);\n};\n\n/**\n * @description 判断是否为视频\n * @param url 文件链接 或 文件名\n */\nexport const isVideoUrl = (url: string): boolean => isFileType(url, FileType.Video);\n\n/**\n * @description 判断是否为图片\n * @param url 文件链接 或 文件名\n */\nexport const isImageUrl = (url: string): boolean => isFileType(url, FileType.Image);\n\n/**\n * @description 判断是否为PDF\n * @param url 文件链接 或 文件名\n */\nexport const isPDF = (url: string): boolean => isFileType(url, FileType.Pdf);\n\n/**\n * @description 是否为Word文档\n * @param url 文件链接 或 文件名\n */\nexport const isWord = (url: string): boolean => isFileType(url, FileType.Word);\n\n/**\n * @description 是否为Excel文件\n * @param url 文件链接 或 文件名\n */\nexport const isExcel = (url: string): boolean => isFileType(url, FileType.Excel);\n\n/**\n * @description 是否为PPT文件\n * @param url 文件链接 或 文件名\n */\nexport const isPPT = (url: string): boolean => isFileType(url, FileType.Ppt);\n\n/**\n * @description 是否为文本文件\n * @param url 文件链接 或 文件名\n */\nexport const isText = (url: string): boolean => isFileType(url, FileType.Text);\n\n/**\n * @description 是否为PSD文件\n * @param url 文件链接 或 文件名\n */\nexport const isPSD = (url: string): boolean => isFileType(url, FileType.Psd);\n\n/**\n * @description 判断是否为压缩包\n * @param url 文件链接 或 文件名\n */\nexport const isZip = (url: string): boolean => isFileType(url, FileType.Zip);\n"],"names":["FileType"],"mappings":"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"}
@@ -32,6 +32,10 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
32
32
  type: BooleanConstructor;
33
33
  default: boolean;
34
34
  };
35
+ disabledDeleteUids: {
36
+ type: import("vue").PropType<number[]>;
37
+ default: () => never[];
38
+ };
35
39
  deleteTip: {
36
40
  type: BooleanConstructor;
37
41
  default: boolean;
@@ -40,6 +44,10 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
40
44
  type: BooleanConstructor;
41
45
  default: boolean;
42
46
  };
47
+ disabledCheckboxUids: {
48
+ type: import("vue").PropType<number[]>;
49
+ default: () => never[];
50
+ };
43
51
  width: {
44
52
  type: NumberConstructor;
45
53
  default: number;
@@ -679,6 +687,10 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
679
687
  type: BooleanConstructor;
680
688
  default: boolean;
681
689
  };
690
+ disabledDeleteUids: {
691
+ type: import("vue").PropType<number[]>;
692
+ default: () => never[];
693
+ };
682
694
  deleteTip: {
683
695
  type: BooleanConstructor;
684
696
  default: boolean;
@@ -687,6 +699,10 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
687
699
  type: BooleanConstructor;
688
700
  default: boolean;
689
701
  };
702
+ disabledCheckboxUids: {
703
+ type: import("vue").PropType<number[]>;
704
+ default: () => never[];
705
+ };
690
706
  width: {
691
707
  type: NumberConstructor;
692
708
  default: number;
@@ -841,7 +857,9 @@ declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<{
841
857
  acl: string;
842
858
  showLoading: boolean;
843
859
  showDelete: boolean;
860
+ disabledDeleteUids: number[];
844
861
  deleteTip: boolean;
862
+ disabledCheckboxUids: number[];
845
863
  }, {}>, {
846
864
  default?(_: {}): any;
847
865
  file?(_: {
@@ -7,7 +7,7 @@ require('./UploadPro.vue3.js');
7
7
  require('./UploadPro.vue4.js');
8
8
  var _pluginVue_exportHelper = require('../../../../_virtual/_plugin-vue_export-helper.js');
9
9
 
10
- var UploadPro = /* @__PURE__ */ _pluginVue_exportHelper.default(UploadPro_vue_vue_type_script_setup_true_lang.default, [["__scopeId", "data-v-ca99928c"]]);
10
+ var UploadPro = /* @__PURE__ */ _pluginVue_exportHelper.default(UploadPro_vue_vue_type_script_setup_true_lang.default, [["__scopeId", "data-v-c948a9bb"]]);
11
11
 
12
12
  exports.default = UploadPro;
13
13
  //# sourceMappingURL=UploadPro.vue.js.map
@@ -13,7 +13,7 @@ var uploadPro = require('./uploadPro.js');
13
13
  var exports$1 = require('../../../../utils/src/elementPlus/exports.js');
14
14
  var index = require('../../../../hooks/base/useUploadFile/index.js');
15
15
 
16
- const _withScopeId = (n) => (vue.pushScopeId("data-v-ca99928c"), n = n(), vue.popScopeId(), n);
16
+ const _withScopeId = (n) => (vue.pushScopeId("data-v-c948a9bb"), n = n(), vue.popScopeId(), n);
17
17
  const _hoisted_1 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ vue.createElementVNode(
18
18
  "div",
19
19
  { class: "el-upload__text gm-text-center !gm-text-xs gm-text-gray-500" },
@@ -61,6 +61,7 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
61
61
  };
62
62
  const coverFileSuccess = (response, uploadFile2, uploadFiles) => {
63
63
  loadingUids.value.delete(uploadFile2.uid);
64
+ uploadFile2.url = response.url;
64
65
  props.onSuccess?.(response, uploadFile2, uploadFiles);
65
66
  };
66
67
  const coverFileError = (error, uploadFile2, uploadFiles) => {
@@ -214,7 +215,7 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
214
215
  _ctx.showFileList && _ctx.listType === "picture-card" ? {
215
216
  name: "file",
216
217
  fn: vue.withCtx(({ file }) => [
217
- _ctx.checkbox ? (vue.openBlock(), vue.createBlock(_component_el_checkbox, {
218
+ _ctx.checkbox && !_ctx.disabledCheckboxUids.includes(file.uid) ? (vue.openBlock(), vue.createBlock(_component_el_checkbox, {
218
219
  key: 0,
219
220
  value: file
220
221
  }, null, 8, ["value"])) : vue.createCommentVNode("v-if", true),
@@ -262,7 +263,7 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
262
263
  /* STABLE */
263
264
  })
264
265
  ], 8, _hoisted_3),
265
- _ctx.showDelete ? (vue.openBlock(), vue.createElementBlock("span", {
266
+ _ctx.showDelete && !_ctx.disabledDeleteUids.includes(file.uid) ? (vue.openBlock(), vue.createElementBlock("span", {
266
267
  key: 0,
267
268
  class: "el-upload-list__item-delete",
268
269
  onClick: ($event) => handleRemove(file, fileList.value)
@@ -1 +1 @@
1
- {"version":3,"file":"UploadPro.vue2.js","sources":["../../../../../../../packages/components/src/business/uploadPro/UploadPro.vue"],"sourcesContent":["<template>\n <div>\n <div\n v-loading=\"uploadLoading\"\n ref=\"pasteFileRef\"\n :class=\"{ 'gm-upload-pro-file-picture-card': listType === 'picture-card', 'gm-upload-pro-file-disabled': disabled }\"\n class=\"gm-upload-pro-file\"\n >\n <el-checkbox-group v-model=\"checkoutFiles\">\n <el-upload\n ref=\"uploadFileRef\"\n v-bind=\"props\"\n v-model:file-list=\"fileList\"\n :before-remove=\"beforeRemove\"\n action=\"\"\n :http-request=\"httpRequest\"\n :on-success=\"coverFileSuccess\"\n :on-error=\"coverFileError\"\n >\n <slot v-if=\"!disabled\">\n <template v-if=\"listType === 'picture-card'\">\n <div\n class=\"gm-flex gm-flex-col gm-items-center gm-justify-center gm-rounded-md gm-border gm-border-dashed gm-p-1\"\n style=\"flex-direction: column\"\n :style=\"{ width: width + 'px', height: height + 'px' }\"\n >\n <el-icon :size=\"30\" color=\"#999\">\n <UploadFilled />\n </el-icon>\n <div class=\"el-upload__text gm-text-center !gm-text-xs gm-text-gray-500\">\n 将文件拖到此处,复制粘贴,或 <em class=\"gm-text-blue-700\">点击上传</em>\n </div>\n </div>\n </template>\n <template v-else>\n <el-button type=\"primary\" size=\"default\">点击上传</el-button>\n </template>\n </slot>\n <template v-if=\"showFileList && listType === 'picture-card'\" #file=\"{ file }\">\n <el-checkbox v-if=\"checkbox\" :value=\"file\" />\n\n <slot name=\"file\" :file=\"file\">\n <div class=\"gm-flex gm-items-center gm-justify-center gm-rounded-md\" :style=\"{ width: width + 'px', height: height + 'px' }\">\n <el-progress\n v-if=\"file.status === 'uploading' || loadingUids.has(file.uid)\"\n :type=\"listType === 'picture-card' ? 'circle' : 'line'\"\n :stroke-width=\"listType === 'picture-card' ? 6 : 2\"\n :percentage=\"Number(file.percentage)\"\n :style=\"\n listType === 'picture-card'\n ? {\n width: width - 20 + 'px',\n height: width - 20 + 'px',\n }\n : 'margin-top: 0.5rem'\n \"\n :width=\"width - 20\"\n />\n\n <GmFileComponent v-else :file=\"file\" :size=\"width - 40\" :controls=\"false\" :show-icon=\"true\" />\n </div>\n <div class=\"el-upload-list__item-actions\">\n <span class=\"el-upload-list__item-preview\" @click=\"handlePreview(file)\">\n <el-icon><View /></el-icon>\n </span>\n <span v-if=\"showDelete\" class=\"el-upload-list__item-delete\" @click=\"handleRemove(file, fileList)\">\n <el-icon><Delete /></el-icon>\n </span>\n </div>\n </slot>\n </template>\n <template v-else #file=\"slotValue\">\n <slot name=\"file\" v-bind=\"slotValue\" />\n </template>\n <template v-if=\"slots.trigger\" #trigger>\n <slot name=\"trigger\" />\n </template>\n <template v-if=\"slots.tip\" #tip>\n <div class=\"gm-text-sm\">\n <slot name=\"tip\" />\n </div>\n </template>\n </el-upload>\n </el-checkbox-group>\n\n <GmPreviewFile v-model:dialogVisible=\"dialogVisible\" v-model:file-index=\"fileIndex\" :file-list=\"fileList\" />\n </div>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ElMessageBox } from 'element-plus';\nimport { computed, ref, useSlots } from 'vue';\n// import { fileValidType } from '@giime/utils/src/file';\n// import { pasteFile } from '@giime/utils/src/pasteFile';\nimport { usePasteFile } from '@giime/hooks/base/usePasteFile';\nimport { GmConfirmBox } from '@giime/components/src/plugins/confirmBox';\nimport { Delete, UploadFilled, View } from '@element-plus/icons-vue';\nimport GmFileComponent from '../../composite/fileComponent';\nimport GmPreviewFile from '../../composite/previewFile';\nimport { GmUploadProUserFileResponse, uploadFileProps } from './uploadPro';\nimport type { UploadFile, UploadFiles, UploadInstance, UploadProps, UploadRawFile } from 'element-plus';\nimport { getGmExports } from '@giime/utils/src/elementPlus/exports';\nimport { useUploadFile } from '@giime/hooks/base/useUploadFile';\n\ndefineOptions({\n name: 'GmUploadPro',\n});\nconst slots = useSlots();\n\nconst props = defineProps(uploadFileProps);\nconst emit = defineEmits([\"handleRemove\"]);\n\n/** 上传文件 */\nconst fileList = defineModel<UploadFile[]>('fileList', { required: true });\n/** 多选数据 */\nconst checkoutFiles = defineModel<any[]>('checkoutFiles', { default: () => [] });\n/**上传功能 */\nconst { uploadFile, cancelUpload } = useUploadFile();\n\nconst loadingUids = ref<Set<number>>(new Set());\nconst uploadLoading = computed(() => props.showLoading && loadingUids.value.size > 0);\n\n/* 上传 */\nconst httpRequest: UploadProps['httpRequest'] = async options => {\n loadingUids.value.add(options.file.uid);\n return uploadFile(options.file, {\n domainCode: props.domainCode,\n sceneCode: props.sceneCode,\n accept: props.accept,\n acl: props.acl,\n elOptions: options,\n });\n};\n// 上传成功\nconst coverFileSuccess: UploadProps['onSuccess'] = (response: GmUploadProUserFileResponse, uploadFile, uploadFiles) => {\n loadingUids.value.delete(uploadFile.uid);\n props.onSuccess?.(response, uploadFile, uploadFiles);\n};\n// 上传失败\nconst coverFileError: UploadProps['onError'] = (error, uploadFile, uploadFiles) => {\n loadingUids.value.delete(uploadFile.uid);\n props.onError?.(error, uploadFile, uploadFiles);\n};\n\n/* 删除文件前 */\nconst beforeRemove: UploadProps['beforeRemove'] = async (file, files) => {\n if (props.disabled) {\n return false;\n }\n if (props.deleteTip) {\n await GmConfirmBox({ message: '确定删除该文件吗?' }, async () => {});\n }\n // 如果文件正在上传,取消上传请求\n if (file.status === 'uploading' || loadingUids.value.has(file.uid)) {\n cancelUpload(file.uid);\n loadingUids.value.delete(file.uid);\n }\n return props.beforeRemove?.(file, files) ?? true;\n};\n\n/* 删除文件 */\nconst removeFile = (file: UploadFile, uploadFiles: UploadFiles) => {\n // 如果文件正在上传,取消上传请求\n if (file.status === 'uploading' || loadingUids.value.has(file.uid)) {\n cancelUpload(file.uid);\n loadingUids.value.delete(file.uid);\n }\n\n const index = fileList.value.indexOf(file);\n if (index > -1) {\n fileList.value.splice(index, 1);\n emit('handleRemove', { file, index });\n return props.onRemove?.(file, uploadFiles);\n }\n};\n/**点击删除图标 */\nconst handleRemove = async (file: UploadFile, uploadFiles: UploadFiles) => {\n if (props.deleteTip) {\n await GmConfirmBox({ message: '确定删除该文件吗?' }, async () => {});\n }\n\n removeFile(file, uploadFiles);\n};\n\nconst uploadFileRef = ref<UploadInstance>();\nconst exposeEvents = ['abort', 'submit', 'clearFiles', 'handleStart', 'handleRemove'] as const;\nconst { exposeFns } = getGmExports(uploadFileRef, exposeEvents);\n\nconst pasteFileRef = ref<HTMLElement>();\n\n/** 预览 */\nconst dialogVisible = ref(false);\nconst fileIndex = ref(0);\n/**点击预览 */\nconst handlePreview = (file: UploadFile) => {\n fileIndex.value = fileList.value.indexOf(file);\n dialogVisible.value = true;\n};\n\n//** 复制粘贴 */\nconst { onSuccess, onError } = usePasteFile(pasteFileRef, { accept: props.accept, disabled: props.disabled });\nonSuccess((files: File[]) => {\n if (props.disabled) {\n return;\n }\n if (Array.isArray(files) && files.length > 0) {\n files.forEach(file => {\n if (file instanceof File) {\n const rawFile = file as UploadRawFile;\n uploadFileRef.value?.handleStart(rawFile);\n\n // 粘贴成功自动上传\n if (props.autoUpload) {\n uploadFileRef.value?.submit();\n }\n }\n });\n }\n});\n/**粘贴失败 */\nonError((error: Error) => {\n console.error('粘贴错误:', error);\n ElMessageBox.alert(error.message, '提示', {\n type: 'error',\n });\n});\ndefineExpose({\n ...exposeFns,\n uploadFileRef,\n});\n</script>\n\n<style scoped lang=\"scss\">\n.gm-upload-pro-preview-dialog {\n :deep(.el-dialog__body) {\n padding: 0;\n }\n}\n.gm-upload-pro-file-picture-card {\n :deep(.el-upload-list__item),\n :deep(.el-upload--picture-card) {\n width: auto;\n height: auto;\n }\n}\n</style>\n<style lang=\"scss\">\n.gm-upload-pro-file {\n line-height: normal;\n .el-checkbox-group {\n font-size: unset;\n }\n .el-checkbox {\n position: absolute;\n left: 10px;\n top: 0;\n z-index: 9;\n }\n .el-upload-list--picture-card {\n gap: 10px;\n }\n .el-upload-list__item {\n margin: 0;\n }\n .el-upload-list__item-file-name {\n line-height: 1.7;\n }\n .el-upload-dragger {\n padding: 0;\n border: none;\n width: 100%;\n height: 100%;\n display: flex;\n }\n .el-upload--picture-card {\n border: none;\n }\n}\n.gm-upload-pro-file-disabled {\n .el-upload--picture-card {\n display: none;\n }\n .el-upload-list__item-status-label {\n display: none;\n }\n}\n</style>\n"],"names":["useSlots","_useModel","useUploadFile","ref","computed","uploadFile","GmConfirmBox","getGmExports","usePasteFile","ElMessageBox"],"mappings":"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"}
1
+ {"version":3,"file":"UploadPro.vue2.js","sources":["../../../../../../../packages/components/src/business/uploadPro/UploadPro.vue"],"sourcesContent":["<template>\n <div>\n <div\n v-loading=\"uploadLoading\"\n ref=\"pasteFileRef\"\n :class=\"{ 'gm-upload-pro-file-picture-card': listType === 'picture-card', 'gm-upload-pro-file-disabled': disabled }\"\n class=\"gm-upload-pro-file\"\n >\n <el-checkbox-group v-model=\"checkoutFiles\">\n <el-upload\n ref=\"uploadFileRef\"\n v-bind=\"props\"\n v-model:file-list=\"fileList\"\n :before-remove=\"beforeRemove\"\n action=\"\"\n :http-request=\"httpRequest\"\n :on-success=\"coverFileSuccess\"\n :on-error=\"coverFileError\"\n >\n <slot v-if=\"!disabled\">\n <template v-if=\"listType === 'picture-card'\">\n <div\n class=\"gm-flex gm-flex-col gm-items-center gm-justify-center gm-rounded-md gm-border gm-border-dashed gm-p-1\"\n style=\"flex-direction: column\"\n :style=\"{ width: width + 'px', height: height + 'px' }\"\n >\n <el-icon :size=\"30\" color=\"#999\">\n <UploadFilled />\n </el-icon>\n <div class=\"el-upload__text gm-text-center !gm-text-xs gm-text-gray-500\">\n 将文件拖到此处,复制粘贴,或 <em class=\"gm-text-blue-700\">点击上传</em>\n </div>\n </div>\n </template>\n <template v-else>\n <el-button type=\"primary\" size=\"default\">点击上传</el-button>\n </template>\n </slot>\n <template v-if=\"showFileList && listType === 'picture-card'\" #file=\"{ file }\">\n <el-checkbox v-if=\"checkbox && !disabledCheckboxUids.includes(file.uid)\" :value=\"file\" />\n\n <slot name=\"file\" :file=\"file\">\n <div class=\"gm-flex gm-items-center gm-justify-center gm-rounded-md\" :style=\"{ width: width + 'px', height: height + 'px' }\">\n <el-progress\n v-if=\"file.status === 'uploading' || loadingUids.has(file.uid)\"\n :type=\"listType === 'picture-card' ? 'circle' : 'line'\"\n :stroke-width=\"listType === 'picture-card' ? 6 : 2\"\n :percentage=\"Number(file.percentage)\"\n :style=\"\n listType === 'picture-card'\n ? {\n width: width - 20 + 'px',\n height: width - 20 + 'px',\n }\n : 'margin-top: 0.5rem'\n \"\n :width=\"width - 20\"\n />\n\n <GmFileComponent v-else :file=\"file\" :size=\"width - 40\" :controls=\"false\" :show-icon=\"true\" />\n </div>\n <div class=\"el-upload-list__item-actions\">\n <span class=\"el-upload-list__item-preview\" @click=\"handlePreview(file)\">\n <el-icon><View /></el-icon>\n </span>\n <span\n v-if=\"showDelete && !disabledDeleteUids.includes(file.uid)\"\n class=\"el-upload-list__item-delete\"\n @click=\"handleRemove(file, fileList)\"\n >\n <el-icon><Delete /></el-icon>\n </span>\n </div>\n </slot>\n </template>\n <template v-else #file=\"slotValue\">\n <slot name=\"file\" v-bind=\"slotValue\" />\n </template>\n <template v-if=\"slots.trigger\" #trigger>\n <slot name=\"trigger\" />\n </template>\n <template v-if=\"slots.tip\" #tip>\n <div class=\"gm-text-sm\">\n <slot name=\"tip\" />\n </div>\n </template>\n </el-upload>\n </el-checkbox-group>\n\n <GmPreviewFile v-model:dialogVisible=\"dialogVisible\" v-model:file-index=\"fileIndex\" :file-list=\"fileList\" />\n </div>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ElMessageBox } from 'element-plus';\nimport { computed, ref, useSlots } from 'vue';\n// import { fileValidType } from '@giime/utils/src/file';\n// import { pasteFile } from '@giime/utils/src/pasteFile';\nimport { usePasteFile } from '@giime/hooks/base/usePasteFile';\nimport { GmConfirmBox } from '@giime/components/src/plugins/confirmBox';\nimport { Delete, UploadFilled, View } from '@element-plus/icons-vue';\nimport GmFileComponent from '../../composite/fileComponent';\nimport GmPreviewFile from '../../composite/previewFile';\nimport { GmUploadProUserFile, GmUploadProUserFileResponse, uploadFileProps } from './uploadPro';\nimport type { UploadFile, UploadFiles, UploadInstance, UploadProps, UploadRawFile } from 'element-plus';\nimport { getGmExports } from '@giime/utils/src/elementPlus/exports';\nimport { useUploadFile } from '@giime/hooks/base/useUploadFile';\n\ndefineOptions({\n name: 'GmUploadPro',\n});\nconst slots = useSlots();\n\nconst props = defineProps(uploadFileProps);\nconst emit = defineEmits([\"handleRemove\"]);\n\n/** 上传文件 */\nconst fileList = defineModel<UploadFile[]>('fileList', { required: true });\n/** 多选数据 */\nconst checkoutFiles = defineModel<any[]>('checkoutFiles', { default: () => [] });\n/**上传功能 */\nconst { uploadFile, cancelUpload } = useUploadFile();\n\nconst loadingUids = ref<Set<number>>(new Set());\nconst uploadLoading = computed(() => props.showLoading && loadingUids.value.size > 0);\n\n/* 上传 */\nconst httpRequest: UploadProps['httpRequest'] = async options => {\n loadingUids.value.add(options.file.uid);\n return uploadFile(options.file, {\n domainCode: props.domainCode,\n sceneCode: props.sceneCode,\n accept: props.accept,\n acl: props.acl,\n elOptions: options,\n });\n};\n// 上传成功\nconst coverFileSuccess: UploadProps['onSuccess'] = (response: GmUploadProUserFileResponse, uploadFile, uploadFiles) => {\n loadingUids.value.delete(uploadFile.uid);\n uploadFile.url = response.url;\n props.onSuccess?.(response, uploadFile, uploadFiles);\n};\n// 上传失败\nconst coverFileError: UploadProps['onError'] = (error, uploadFile, uploadFiles) => {\n loadingUids.value.delete(uploadFile.uid);\n props.onError?.(error, uploadFile, uploadFiles);\n};\n\n/* 删除文件前 */\nconst beforeRemove: UploadProps['beforeRemove'] = async (file, files) => {\n if (props.disabled) {\n return false;\n }\n if (props.deleteTip) {\n await GmConfirmBox({ message: '确定删除该文件吗?' }, async () => {});\n }\n // 如果文件正在上传,取消上传请求\n if (file.status === 'uploading' || loadingUids.value.has(file.uid)) {\n cancelUpload(file.uid);\n loadingUids.value.delete(file.uid);\n }\n return props.beforeRemove?.(file, files) ?? true;\n};\n\n/* 删除文件 */\nconst removeFile = (file: UploadFile, uploadFiles: UploadFiles) => {\n // 如果文件正在上传,取消上传请求\n if (file.status === 'uploading' || loadingUids.value.has(file.uid)) {\n cancelUpload(file.uid);\n loadingUids.value.delete(file.uid);\n }\n\n const index = fileList.value.indexOf(file);\n if (index > -1) {\n fileList.value.splice(index, 1);\n emit('handleRemove', { file, index });\n return props.onRemove?.(file, uploadFiles);\n }\n};\n/**点击删除图标 */\nconst handleRemove = async (file: UploadFile, uploadFiles: UploadFiles) => {\n if (props.deleteTip) {\n await GmConfirmBox({ message: '确定删除该文件吗?' }, async () => {});\n }\n\n removeFile(file, uploadFiles);\n};\n\nconst uploadFileRef = ref<UploadInstance>();\nconst exposeEvents = ['abort', 'submit', 'clearFiles', 'handleStart', 'handleRemove'] as const;\nconst { exposeFns } = getGmExports(uploadFileRef, exposeEvents);\n\nconst pasteFileRef = ref<HTMLElement>();\n\n/** 预览 */\nconst dialogVisible = ref(false);\nconst fileIndex = ref(0);\n/**点击预览 */\nconst handlePreview = (file: UploadFile) => {\n fileIndex.value = fileList.value.indexOf(file);\n dialogVisible.value = true;\n};\n\n//** 复制粘贴 */\nconst { onSuccess, onError } = usePasteFile(pasteFileRef, { accept: props.accept, disabled: props.disabled });\nonSuccess((files: File[]) => {\n if (props.disabled) {\n return;\n }\n if (Array.isArray(files) && files.length > 0) {\n files.forEach(file => {\n if (file instanceof File) {\n const rawFile = file as UploadRawFile;\n uploadFileRef.value?.handleStart(rawFile);\n\n // 粘贴成功自动上传\n if (props.autoUpload) {\n uploadFileRef.value?.submit();\n }\n }\n });\n }\n});\n/**粘贴失败 */\nonError((error: Error) => {\n console.error('粘贴错误:', error);\n ElMessageBox.alert(error.message, '提示', {\n type: 'error',\n });\n});\ndefineExpose({\n ...exposeFns,\n uploadFileRef,\n});\n</script>\n\n<style scoped lang=\"scss\">\n.gm-upload-pro-preview-dialog {\n :deep(.el-dialog__body) {\n padding: 0;\n }\n}\n.gm-upload-pro-file-picture-card {\n :deep(.el-upload-list__item),\n :deep(.el-upload--picture-card) {\n width: auto;\n height: auto;\n }\n}\n</style>\n<style lang=\"scss\">\n.gm-upload-pro-file {\n line-height: normal;\n .el-checkbox-group {\n font-size: unset;\n }\n .el-checkbox {\n position: absolute;\n left: 10px;\n top: 0;\n z-index: 9;\n }\n .el-upload-list--picture-card {\n gap: 10px;\n }\n .el-upload-list__item {\n margin: 0;\n }\n .el-upload-list__item-file-name {\n line-height: 1.7;\n }\n .el-upload-dragger {\n padding: 0;\n border: none;\n width: 100%;\n height: 100%;\n display: flex;\n }\n .el-upload--picture-card {\n border: none;\n }\n}\n.gm-upload-pro-file-disabled {\n .el-upload--picture-card {\n display: none;\n }\n .el-upload-list__item-status-label {\n display: none;\n }\n}\n</style>\n"],"names":["useSlots","_useModel","useUploadFile","ref","computed","uploadFile","GmConfirmBox","getGmExports","usePasteFile","ElMessageBox"],"mappings":"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"}
@@ -33,6 +33,10 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
33
33
  type: BooleanConstructor;
34
34
  default: boolean;
35
35
  };
36
+ disabledDeleteUids: {
37
+ type: import("vue").PropType<number[]>;
38
+ default: () => never[];
39
+ };
36
40
  deleteTip: {
37
41
  type: BooleanConstructor;
38
42
  default: boolean;
@@ -41,6 +45,10 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
41
45
  type: BooleanConstructor;
42
46
  default: boolean;
43
47
  };
48
+ disabledCheckboxUids: {
49
+ type: import("vue").PropType<number[]>;
50
+ default: () => never[];
51
+ };
44
52
  width: {
45
53
  type: NumberConstructor;
46
54
  default: number;
@@ -687,6 +695,10 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
687
695
  type: BooleanConstructor;
688
696
  default: boolean;
689
697
  };
698
+ disabledDeleteUids: {
699
+ type: import("vue").PropType<number[]>;
700
+ default: () => never[];
701
+ };
690
702
  deleteTip: {
691
703
  type: BooleanConstructor;
692
704
  default: boolean;
@@ -695,6 +707,10 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
695
707
  type: BooleanConstructor;
696
708
  default: boolean;
697
709
  };
710
+ disabledCheckboxUids: {
711
+ type: import("vue").PropType<number[]>;
712
+ default: () => never[];
713
+ };
698
714
  width: {
699
715
  type: NumberConstructor;
700
716
  default: number;
@@ -849,7 +865,9 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
849
865
  acl: string;
850
866
  showLoading: boolean;
851
867
  showDelete: boolean;
868
+ disabledDeleteUids: number[];
852
869
  deleteTip: boolean;
870
+ disabledCheckboxUids: number[];
853
871
  }, true, {}, {}, {
854
872
  P: {};
855
873
  B: {};
@@ -890,6 +908,10 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
890
908
  type: BooleanConstructor;
891
909
  default: boolean;
892
910
  };
911
+ disabledDeleteUids: {
912
+ type: import("vue").PropType<number[]>;
913
+ default: () => never[];
914
+ };
893
915
  deleteTip: {
894
916
  type: BooleanConstructor;
895
917
  default: boolean;
@@ -898,6 +920,10 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
898
920
  type: BooleanConstructor;
899
921
  default: boolean;
900
922
  };
923
+ disabledCheckboxUids: {
924
+ type: import("vue").PropType<number[]>;
925
+ default: () => never[];
926
+ };
901
927
  width: {
902
928
  type: NumberConstructor;
903
929
  default: number;
@@ -1533,7 +1559,9 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
1533
1559
  acl: string;
1534
1560
  showLoading: boolean;
1535
1561
  showDelete: boolean;
1562
+ disabledDeleteUids: number[];
1536
1563
  deleteTip: boolean;
1564
+ disabledCheckboxUids: number[];
1537
1565
  }>;
1538
1566
  __isFragment?: undefined;
1539
1567
  __isTeleport?: undefined;
@@ -1571,6 +1599,10 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
1571
1599
  type: BooleanConstructor;
1572
1600
  default: boolean;
1573
1601
  };
1602
+ disabledDeleteUids: {
1603
+ type: import("vue").PropType<number[]>;
1604
+ default: () => never[];
1605
+ };
1574
1606
  deleteTip: {
1575
1607
  type: BooleanConstructor;
1576
1608
  default: boolean;
@@ -1579,6 +1611,10 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
1579
1611
  type: BooleanConstructor;
1580
1612
  default: boolean;
1581
1613
  };
1614
+ disabledCheckboxUids: {
1615
+ type: import("vue").PropType<number[]>;
1616
+ default: () => never[];
1617
+ };
1582
1618
  width: {
1583
1619
  type: NumberConstructor;
1584
1620
  default: number;
@@ -2221,7 +2257,9 @@ export declare const GmUploadPro: import("../../../../utils").SFCWithInstall<{
2221
2257
  acl: string;
2222
2258
  showLoading: boolean;
2223
2259
  showDelete: boolean;
2260
+ disabledDeleteUids: number[];
2224
2261
  deleteTip: boolean;
2262
+ disabledCheckboxUids: number[];
2225
2263
  }, {}, string, {}> & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps & (new () => {
2226
2264
  $slots: {
2227
2265
  default?(_: {}): any;
@@ -34,6 +34,11 @@ export declare const uploadFileProps: {
34
34
  type: BooleanConstructor;
35
35
  default: boolean;
36
36
  };
37
+ /**禁用删除按钮的uid列表 */
38
+ disabledDeleteUids: {
39
+ type: PropType<number[]>;
40
+ default: () => never[];
41
+ };
37
42
  /** 删除时提示 */
38
43
  deleteTip: {
39
44
  type: BooleanConstructor;
@@ -44,6 +49,11 @@ export declare const uploadFileProps: {
44
49
  type: BooleanConstructor;
45
50
  default: boolean;
46
51
  };
52
+ /**禁用多选按钮的uid列表 */
53
+ disabledCheckboxUids: {
54
+ type: PropType<number[]>;
55
+ default: () => never[];
56
+ };
47
57
  /** 缩略图宽度 */
48
58
  width: {
49
59
  type: NumberConstructor;
@@ -37,6 +37,11 @@ const uploadFileProps = {
37
37
  type: Boolean,
38
38
  default: true
39
39
  },
40
+ /**禁用删除按钮的uid列表 */
41
+ disabledDeleteUids: {
42
+ type: Array,
43
+ default: () => []
44
+ },
40
45
  /** 删除时提示 */
41
46
  deleteTip: {
42
47
  type: Boolean,
@@ -47,6 +52,11 @@ const uploadFileProps = {
47
52
  type: Boolean,
48
53
  default: false
49
54
  },
55
+ /**禁用多选按钮的uid列表 */
56
+ disabledCheckboxUids: {
57
+ type: Array,
58
+ default: () => []
59
+ },
50
60
  /** 缩略图宽度 */
51
61
  width: {
52
62
  type: Number,
@@ -1 +1 @@
1
- {"version":3,"file":"uploadPro.js","sources":["../../../../../../../packages/components/src/business/uploadPro/uploadPro.ts"],"sourcesContent":["import { type PropType } from 'vue';\nimport { type UploadFile, type UploadProps, uploadProps, type UploadUserFile } from 'element-plus';\nimport type { ResourceUrlResponse } from '@giime/api/resource/interface';\n// import { previewFileProps } from '../../composite/previewFile/previewFile';\n\nexport const uploadFileProps = {\n ...uploadProps,\n // ...previewFileProps,\n listType: {\n type: String as PropType<UploadProps['listType']>,\n default: 'picture-card',\n },\n drag: {\n type: Boolean,\n default: true,\n },\n /**领域编码 */\n domainCode: {\n type: String,\n },\n /**场景编码 */\n sceneCode: {\n type: String,\n default: 'internal_oss',\n },\n /** 文件权限,默认继承桶 */\n acl: {\n type: String,\n default: 'default',\n },\n /**上传中是否loading */\n showLoading: {\n type: Boolean,\n default: false,\n },\n /** 是否展示删除按钮 */\n showDelete: {\n type: Boolean,\n default: true,\n },\n /** 删除时提示 */\n deleteTip: {\n type: Boolean,\n default: false,\n },\n /** 是否开启文件多选 */\n checkbox: {\n type: Boolean,\n default: false,\n },\n /** 缩略图宽度 */\n width: {\n type: Number,\n default: 120,\n },\n /** 缩略图高度 */\n height: {\n type: Number,\n default: 120,\n },\n};\nexport type GmUploadProUserFileResponse = ResourceUrlResponse;\n\nexport type GmUploadProUserFile = Omit<UploadUserFile, 'response'> & { response?: GmUploadProUserFileResponse };\n"],"names":["uploadProps"],"mappings":";;;;AAKO,MAAM,eAAkB,GAAA;AAAA,EAC7B,GAAGA,uBAAA;AAAA;AAAA,EAEH,QAAU,EAAA;AAAA,IACR,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,cAAA;AAAA,GACX;AAAA,EACA,IAAM,EAAA;AAAA,IACJ,IAAM,EAAA,OAAA;AAAA,IACN,OAAS,EAAA,IAAA;AAAA,GACX;AAAA;AAAA,EAEA,UAAY,EAAA;AAAA,IACV,IAAM,EAAA,MAAA;AAAA,GACR;AAAA;AAAA,EAEA,SAAW,EAAA;AAAA,IACT,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,cAAA;AAAA,GACX;AAAA;AAAA,EAEA,GAAK,EAAA;AAAA,IACH,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,SAAA;AAAA,GACX;AAAA;AAAA,EAEA,WAAa,EAAA;AAAA,IACX,IAAM,EAAA,OAAA;AAAA,IACN,OAAS,EAAA,KAAA;AAAA,GACX;AAAA;AAAA,EAEA,UAAY,EAAA;AAAA,IACV,IAAM,EAAA,OAAA;AAAA,IACN,OAAS,EAAA,IAAA;AAAA,GACX;AAAA;AAAA,EAEA,SAAW,EAAA;AAAA,IACT,IAAM,EAAA,OAAA;AAAA,IACN,OAAS,EAAA,KAAA;AAAA,GACX;AAAA;AAAA,EAEA,QAAU,EAAA;AAAA,IACR,IAAM,EAAA,OAAA;AAAA,IACN,OAAS,EAAA,KAAA;AAAA,GACX;AAAA;AAAA,EAEA,KAAO,EAAA;AAAA,IACL,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,GAAA;AAAA,GACX;AAAA;AAAA,EAEA,MAAQ,EAAA;AAAA,IACN,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,GAAA;AAAA,GACX;AACF;;;;"}
1
+ {"version":3,"file":"uploadPro.js","sources":["../../../../../../../packages/components/src/business/uploadPro/uploadPro.ts"],"sourcesContent":["import { type PropType } from 'vue';\nimport { type UploadFile, type UploadProps, uploadProps, type UploadUserFile } from 'element-plus';\nimport type { ResourceUrlResponse } from '@giime/api/resource/interface';\n// import { previewFileProps } from '../../composite/previewFile/previewFile';\n\nexport const uploadFileProps = {\n ...uploadProps,\n // ...previewFileProps,\n listType: {\n type: String as PropType<UploadProps['listType']>,\n default: 'picture-card',\n },\n drag: {\n type: Boolean,\n default: true,\n },\n /**领域编码 */\n domainCode: {\n type: String,\n },\n /**场景编码 */\n sceneCode: {\n type: String,\n default: 'internal_oss',\n },\n /** 文件权限,默认继承桶 */\n acl: {\n type: String,\n default: 'default',\n },\n /**上传中是否loading */\n showLoading: {\n type: Boolean,\n default: false,\n },\n /** 是否展示删除按钮 */\n showDelete: {\n type: Boolean,\n default: true,\n },\n /**禁用删除按钮的uid列表 */\n disabledDeleteUids: {\n type: Array as PropType<number[]>,\n default: () => [],\n },\n /** 删除时提示 */\n deleteTip: {\n type: Boolean,\n default: false,\n },\n /** 是否开启文件多选 */\n checkbox: {\n type: Boolean,\n default: false,\n },\n /**禁用多选按钮的uid列表 */\n disabledCheckboxUids: {\n type: Array as PropType<number[]>,\n default: () => [],\n },\n /** 缩略图宽度 */\n width: {\n type: Number,\n default: 120,\n },\n /** 缩略图高度 */\n height: {\n type: Number,\n default: 120,\n },\n};\nexport type GmUploadProUserFileResponse = ResourceUrlResponse;\n\nexport type GmUploadProUserFile = Omit<UploadUserFile, 'response'> & { response?: GmUploadProUserFileResponse };\n"],"names":["uploadProps"],"mappings":";;;;AAKO,MAAM,eAAkB,GAAA;AAAA,EAC7B,GAAGA,uBAAA;AAAA;AAAA,EAEH,QAAU,EAAA;AAAA,IACR,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,cAAA;AAAA,GACX;AAAA,EACA,IAAM,EAAA;AAAA,IACJ,IAAM,EAAA,OAAA;AAAA,IACN,OAAS,EAAA,IAAA;AAAA,GACX;AAAA;AAAA,EAEA,UAAY,EAAA;AAAA,IACV,IAAM,EAAA,MAAA;AAAA,GACR;AAAA;AAAA,EAEA,SAAW,EAAA;AAAA,IACT,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,cAAA;AAAA,GACX;AAAA;AAAA,EAEA,GAAK,EAAA;AAAA,IACH,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,SAAA;AAAA,GACX;AAAA;AAAA,EAEA,WAAa,EAAA;AAAA,IACX,IAAM,EAAA,OAAA;AAAA,IACN,OAAS,EAAA,KAAA;AAAA,GACX;AAAA;AAAA,EAEA,UAAY,EAAA;AAAA,IACV,IAAM,EAAA,OAAA;AAAA,IACN,OAAS,EAAA,IAAA;AAAA,GACX;AAAA;AAAA,EAEA,kBAAoB,EAAA;AAAA,IAClB,IAAM,EAAA,KAAA;AAAA,IACN,OAAA,EAAS,MAAM,EAAC;AAAA,GAClB;AAAA;AAAA,EAEA,SAAW,EAAA;AAAA,IACT,IAAM,EAAA,OAAA;AAAA,IACN,OAAS,EAAA,KAAA;AAAA,GACX;AAAA;AAAA,EAEA,QAAU,EAAA;AAAA,IACR,IAAM,EAAA,OAAA;AAAA,IACN,OAAS,EAAA,KAAA;AAAA,GACX;AAAA;AAAA,EAEA,oBAAsB,EAAA;AAAA,IACpB,IAAM,EAAA,KAAA;AAAA,IACN,OAAA,EAAS,MAAM,EAAC;AAAA,GAClB;AAAA;AAAA,EAEA,KAAO,EAAA;AAAA,IACL,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,GAAA;AAAA,GACX;AAAA;AAAA,EAEA,MAAQ,EAAA;AAAA,IACN,IAAM,EAAA,MAAA;AAAA,IACN,OAAS,EAAA,GAAA;AAAA,GACX;AACF;;;;"}
@@ -30,10 +30,10 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
30
30
  const verifyFile = vue.computed(() => {
31
31
  return props.file[props.field];
32
32
  });
33
+ const isImageFile = vue.computed(() => is.isImageUrl(fileURL.value) || is.isImageUrl(verifyFile.value));
34
+ const isVideoFile = vue.computed(() => is.isVideoUrl(fileURL.value) || is.isVideoUrl(verifyFile.value));
33
35
  const showIframe = vue.computed(() => {
34
- const arr = ["pdf", "txt"];
35
- const suffix = verifyFile.value.split(".").pop();
36
- return arr.includes(suffix);
36
+ return is.isPDF(fileURL.value) || is.isPDF(verifyFile.value) || is.isText(fileURL.value) || is.isText(verifyFile.value);
37
37
  });
38
38
  const iconList = {
39
39
  excel: "https://sucai.giikin.cn/workflow/material-refer-1739947054012-1213-335.svg",
@@ -46,36 +46,27 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
46
46
  unknown: "https://sucai.giikin.cn/workflow/material-refer-1739947288698-1448-736.svg"
47
47
  };
48
48
  const iconURL = vue.computed(() => {
49
- const verifyFile2 = props.file[props.field];
50
- let result = null;
51
- if (is.isPDF(verifyFile2)) {
52
- result = iconList.pdf;
53
- } else if (is.isWord(verifyFile2)) {
54
- result = iconList.word;
55
- } else if (is.isExcel(verifyFile2)) {
56
- result = iconList.excel;
57
- } else if (is.isText(verifyFile2)) {
58
- result = iconList.txt;
59
- } else if (is.isPPT(verifyFile2)) {
60
- result = iconList.ppt;
61
- } else if (is.isZip(verifyFile2)) {
62
- result = iconList.zip;
63
- } else if (is.isPSD(verifyFile2)) {
64
- result = iconList.psd;
65
- } else {
66
- result = iconList.unknown;
67
- }
68
- return result;
49
+ const typeCheckers = [
50
+ { check: () => is.isPDF(fileURL.value) || is.isPDF(verifyFile.value), icon: iconList.pdf },
51
+ { check: () => is.isWord(fileURL.value) || is.isWord(verifyFile.value), icon: iconList.word },
52
+ { check: () => is.isExcel(fileURL.value) || is.isExcel(verifyFile.value), icon: iconList.excel },
53
+ { check: () => is.isText(fileURL.value) || is.isText(verifyFile.value), icon: iconList.txt },
54
+ { check: () => is.isPPT(fileURL.value) || is.isPPT(verifyFile.value), icon: iconList.ppt },
55
+ { check: () => is.isZip(fileURL.value) || is.isZip(verifyFile.value), icon: iconList.zip },
56
+ { check: () => is.isPSD(fileURL.value) || is.isPSD(verifyFile.value), icon: iconList.psd }
57
+ ];
58
+ const matchedType = typeCheckers.find(({ check }) => check());
59
+ return matchedType?.icon || iconList.unknown;
69
60
  });
70
61
  return (_ctx, _cache) => {
71
62
  const _component_el_image = vue.resolveComponent("el-image");
72
63
  return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
73
- vue.unref(is.isImageUrl)(verifyFile.value) ? (vue.openBlock(), vue.createElementBlock("img", {
64
+ isImageFile.value ? (vue.openBlock(), vue.createElementBlock("img", {
74
65
  key: 0,
75
66
  src: fileURL.value,
76
67
  fit: "contain",
77
68
  style: { "max-width": "100%", "max-height": "100%" }
78
- }, null, 8, _hoisted_2)) : vue.unref(is.isVideoUrl)(verifyFile.value) ? (vue.openBlock(), vue.createElementBlock("video", {
69
+ }, null, 8, _hoisted_2)) : isVideoFile.value ? (vue.openBlock(), vue.createElementBlock("video", {
79
70
  key: 1,
80
71
  src: fileURL.value,
81
72
  controls: _ctx.controls,
@@ -1 +1 @@
1
- {"version":3,"file":"FileComponent.vue2.js","sources":["../../../../../../../packages/components/src/composite/fileComponent/FileComponent.vue"],"sourcesContent":["<template>\n <div class=\"gm-flex gm-h-full gm-items-center gm-justify-center\">\n <img v-if=\"isImageUrl(verifyFile)\" :src=\"fileURL\" fit=\"contain\" style=\"max-width: 100%; max-height: 100%\" />\n <video\n v-else-if=\"isVideoUrl(verifyFile)\"\n :src=\"fileURL\"\n :controls=\"controls\"\n :controlslist=\"controlslist\"\n :oncontextmenu=\"() => oncontextmenu\"\n style=\"width: 100%; height: 100%\"\n />\n <template v-else>\n <el-image v-if=\"showIcon || !showIframe\" :style=\"iconStyle\" :src=\"iconURL\" />\n <iframe v-else :src=\"fileURL\" width=\"850px\" height=\"100%\" frameborder=\"0\" />\n </template>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed } from 'vue';\nimport { isExcel, isImageUrl, isPDF, isPPT, isPSD, isText, isVideoUrl, isWord, isZip } from '@giime/utils/src/is';\nimport { fileComponentProps } from './fileComponent';\n// import PDF from './assets/image/pdf.svg';\n// import WORD from './assets/image/word.svg';\n// import EXCEL from './assets/image/excel.svg';\n// import PPT from './assets/image/ppt.svg';\n// import PSD from './assets/image/psd.svg';\n// import TEXT from './assets/image/text.svg';\n// import ZIP from './assets/image/zip.svg';\n// import UNKNOWN from './assets/image/unknown.svg';\nimport type { UploadFile } from 'element-plus';\n\ndefineOptions({\n name: 'GmFileComponent',\n});\n\nconst props = defineProps(fileComponentProps);\n\nconst iconStyle = computed(() => {\n return {\n width: `${props.size}px`,\n height: `${props.size}px`,\n };\n});\n\n/** 文件链接地址 */\nconst fileURL = computed(() => {\n return props.file[props.url as keyof UploadFile] as string;\n});\n\n/** 验证文件类型的字段 */\nconst verifyFile = computed(() => {\n return props.file[props.field as keyof UploadFile] as string;\n});\n\n/** 显示iframe */\nconst showIframe = computed(() => {\n const arr = ['pdf', 'txt'];\n const suffix = verifyFile.value.split('.').pop();\n\n return arr.includes(suffix as string);\n});\n\n/** 图标 */\nconst iconList = {\n excel: 'https://sucai.giikin.cn/workflow/material-refer-1739947054012-1213-335.svg',\n pdf: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-5462-586.svg',\n word: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-1540-625.svg',\n txt: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-1700-90.svg',\n zip: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-2639-507.svg',\n psd: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-5026-760.svg',\n ppt: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-2867-970.svg',\n unknown: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-1448-736.svg',\n};\n\nconst iconURL = computed<string>(() => {\n const verifyFile = props.file[props.field as keyof UploadFile] as string;\n let result: any = null;\n if (isPDF(verifyFile)) {\n result = iconList.pdf;\n } else if (isWord(verifyFile)) {\n result = iconList.word;\n } else if (isExcel(verifyFile)) {\n result = iconList.excel;\n } else if (isText(verifyFile)) {\n result = iconList.txt;\n } else if (isPPT(verifyFile)) {\n result = iconList.ppt;\n } else if (isZip(verifyFile)) {\n result = iconList.zip;\n } else if (isPSD(verifyFile)) {\n result = iconList.psd;\n } else {\n result = iconList.unknown;\n }\n return result;\n});\n</script>\n"],"names":["computed","verifyFile","isPDF","isWord","isExcel","isText","isPPT","isZip","isPSD"],"mappings":";;;;;;;;;;;;;;;;;;;AAoCA,IAAA,MAAM,KAAQ,GAAA,OAAA,CAAA;AAEd,IAAM,MAAA,SAAA,GAAYA,aAAS,MAAM;AAC/B,MAAO,OAAA;AAAA,QACL,KAAA,EAAO,CAAG,EAAA,KAAA,CAAM,IAAI,CAAA,EAAA,CAAA;AAAA,QACpB,MAAA,EAAQ,CAAG,EAAA,KAAA,CAAM,IAAI,CAAA,EAAA,CAAA;AAAA,OACvB,CAAA;AAAA,KACD,CAAA,CAAA;AAGD,IAAM,MAAA,OAAA,GAAUA,aAAS,MAAM;AAC7B,MAAO,OAAA,KAAA,CAAM,IAAK,CAAA,KAAA,CAAM,GAAuB,CAAA,CAAA;AAAA,KAChD,CAAA,CAAA;AAGD,IAAM,MAAA,UAAA,GAAaA,aAAS,MAAM;AAChC,MAAO,OAAA,KAAA,CAAM,IAAK,CAAA,KAAA,CAAM,KAAyB,CAAA,CAAA;AAAA,KAClD,CAAA,CAAA;AAGD,IAAM,MAAA,UAAA,GAAaA,aAAS,MAAM;AAChC,MAAM,MAAA,GAAA,GAAM,CAAC,KAAA,EAAO,KAAK,CAAA,CAAA;AACzB,MAAA,MAAM,SAAS,UAAW,CAAA,KAAA,CAAM,KAAM,CAAA,GAAG,EAAE,GAAI,EAAA,CAAA;AAE/C,MAAO,OAAA,GAAA,CAAI,SAAS,MAAgB,CAAA,CAAA;AAAA,KACrC,CAAA,CAAA;AAGD,IAAA,MAAM,QAAW,GAAA;AAAA,MACf,KAAO,EAAA,4EAAA;AAAA,MACP,GAAK,EAAA,4EAAA;AAAA,MACL,IAAM,EAAA,4EAAA;AAAA,MACN,GAAK,EAAA,2EAAA;AAAA,MACL,GAAK,EAAA,4EAAA;AAAA,MACL,GAAK,EAAA,4EAAA;AAAA,MACL,GAAK,EAAA,4EAAA;AAAA,MACL,OAAS,EAAA,4EAAA;AAAA,KACX,CAAA;AAEA,IAAM,MAAA,OAAA,GAAUA,aAAiB,MAAM;AACrC,MAAA,MAAMC,WAAa,GAAA,KAAA,CAAM,IAAK,CAAA,KAAA,CAAM,KAAyB,CAAA,CAAA;AAC7D,MAAA,IAAI,MAAc,GAAA,IAAA,CAAA;AAClB,MAAI,IAAAC,QAAA,CAAMD,WAAU,CAAG,EAAA;AACrB,QAAA,MAAA,GAAS,QAAS,CAAA,GAAA,CAAA;AAAA,OACpB,MAAA,IAAWE,SAAOF,CAAAA,WAAU,CAAG,EAAA;AAC7B,QAAA,MAAA,GAAS,QAAS,CAAA,IAAA,CAAA;AAAA,OACpB,MAAA,IAAWG,UAAQH,CAAAA,WAAU,CAAG,EAAA;AAC9B,QAAA,MAAA,GAAS,QAAS,CAAA,KAAA,CAAA;AAAA,OACpB,MAAA,IAAWI,SAAOJ,CAAAA,WAAU,CAAG,EAAA;AAC7B,QAAA,MAAA,GAAS,QAAS,CAAA,GAAA,CAAA;AAAA,OACpB,MAAA,IAAWK,QAAML,CAAAA,WAAU,CAAG,EAAA;AAC5B,QAAA,MAAA,GAAS,QAAS,CAAA,GAAA,CAAA;AAAA,OACpB,MAAA,IAAWM,QAAMN,CAAAA,WAAU,CAAG,EAAA;AAC5B,QAAA,MAAA,GAAS,QAAS,CAAA,GAAA,CAAA;AAAA,OACpB,MAAA,IAAWO,QAAMP,CAAAA,WAAU,CAAG,EAAA;AAC5B,QAAA,MAAA,GAAS,QAAS,CAAA,GAAA,CAAA;AAAA,OACb,MAAA;AACL,QAAA,MAAA,GAAS,QAAS,CAAA,OAAA,CAAA;AAAA,OACpB;AACA,MAAO,OAAA,MAAA,CAAA;AAAA,KACR,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"FileComponent.vue2.js","sources":["../../../../../../../packages/components/src/composite/fileComponent/FileComponent.vue"],"sourcesContent":["<template>\n <div class=\"gm-flex gm-h-full gm-items-center gm-justify-center\">\n <img v-if=\"isImageFile\" :src=\"fileURL\" fit=\"contain\" style=\"max-width: 100%; max-height: 100%\" />\n <video\n v-else-if=\"isVideoFile\"\n :src=\"fileURL\"\n :controls=\"controls\"\n :controlslist=\"controlslist\"\n :oncontextmenu=\"() => oncontextmenu\"\n style=\"width: 100%; height: 100%\"\n />\n <template v-else>\n <el-image v-if=\"showIcon || !showIframe\" :style=\"iconStyle\" :src=\"iconURL\" />\n <iframe v-else :src=\"fileURL\" width=\"850px\" height=\"100%\" frameborder=\"0\" />\n </template>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed } from 'vue';\nimport { isExcel, isImageUrl, isPDF, isPPT, isPSD, isText, isVideoUrl, isWord, isZip } from '@giime/utils/src/is';\nimport { fileComponentProps } from './fileComponent';\n// import PDF from './assets/image/pdf.svg';\n// import WORD from './assets/image/word.svg';\n// import EXCEL from './assets/image/excel.svg';\n// import PPT from './assets/image/ppt.svg';\n// import PSD from './assets/image/psd.svg';\n// import TEXT from './assets/image/text.svg';\n// import ZIP from './assets/image/zip.svg';\n// import UNKNOWN from './assets/image/unknown.svg';\nimport type { UploadFile } from 'element-plus';\n\ndefineOptions({\n name: 'GmFileComponent',\n});\n\nconst props = defineProps(fileComponentProps);\n\nconst iconStyle = computed(() => {\n return {\n width: `${props.size}px`,\n height: `${props.size}px`,\n };\n});\n\n/** 文件链接地址 */\nconst fileURL = computed(() => {\n return props.file[props.url as keyof UploadFile] as string;\n});\n\n/** 验证文件类型的字段 */\nconst verifyFile = computed(() => {\n return props.file[props.field as keyof UploadFile] as string;\n});\n\nconst isImageFile = computed(() => isImageUrl(fileURL.value) || isImageUrl(verifyFile.value));\nconst isVideoFile = computed(() => isVideoUrl(fileURL.value) || isVideoUrl(verifyFile.value));\n\n/** 显示iframe */\nconst showIframe = computed(() => {\n return isPDF(fileURL.value) || isPDF(verifyFile.value) || isText(fileURL.value) || isText(verifyFile.value);\n});\n\n/** 图标 */\nconst iconList = {\n excel: 'https://sucai.giikin.cn/workflow/material-refer-1739947054012-1213-335.svg',\n pdf: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-5462-586.svg',\n word: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-1540-625.svg',\n txt: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-1700-90.svg',\n zip: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-2639-507.svg',\n psd: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-5026-760.svg',\n ppt: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-2867-970.svg',\n unknown: 'https://sucai.giikin.cn/workflow/material-refer-1739947288698-1448-736.svg',\n};\n\nconst iconURL = computed<string>(() => {\n // 文件类型检查器映射\n const typeCheckers = [\n { check: () => isPDF(fileURL.value) || isPDF(verifyFile.value), icon: iconList.pdf },\n { check: () => isWord(fileURL.value) || isWord(verifyFile.value), icon: iconList.word },\n { check: () => isExcel(fileURL.value) || isExcel(verifyFile.value), icon: iconList.excel },\n { check: () => isText(fileURL.value) || isText(verifyFile.value), icon: iconList.txt },\n { check: () => isPPT(fileURL.value) || isPPT(verifyFile.value), icon: iconList.ppt },\n { check: () => isZip(fileURL.value) || isZip(verifyFile.value), icon: iconList.zip },\n { check: () => isPSD(fileURL.value) || isPSD(verifyFile.value), icon: iconList.psd },\n ];\n\n // 查找匹配的文件类型\n const matchedType = typeCheckers.find(({ check }) => check());\n\n return matchedType?.icon || iconList.unknown;\n});\n</script>\n"],"names":["computed","isImageUrl","isVideoUrl","isPDF","isText","isWord","isExcel","isPPT","isZip","isPSD"],"mappings":"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"}
@@ -1,3 +1,3 @@
1
- export declare const GmConfirmBox: import("../../../../utils").SFCInstallWithContext<(options: import("./method").ConfirmBoxOptions, handle: () => Promise<any>) => Promise<void>>;
1
+ export declare const GmConfirmBox: import("../../../../utils").SFCInstallWithContext<(options: import("./method").ConfirmBoxOptions, handle?: (() => Promise<any>) | undefined) => Promise<void>>;
2
2
  export { type ConfirmBoxOptions } from './method';
3
3
  export default GmConfirmBox;
@@ -2,4 +2,4 @@ export interface ConfirmBoxOptions {
2
2
  message: string;
3
3
  title?: string;
4
4
  }
5
- export declare const confirmBox: (options: ConfirmBoxOptions, handle: () => Promise<any>) => Promise<void>;
5
+ export declare const confirmBox: (options: ConfirmBoxOptions, handle?: () => Promise<any>) => Promise<void>;
@@ -11,10 +11,10 @@ const confirmBox = async (options, handle) => {
11
11
  if (action === "confirm") {
12
12
  instance.confirmButtonLoading = true;
13
13
  try {
14
- await handle();
14
+ await handle?.();
15
15
  done();
16
- } catch (e) {
17
- console.error(e);
16
+ instance.confirmButtonDisabled = true;
17
+ } finally {
18
18
  instance.confirmButtonLoading = false;
19
19
  }
20
20
  } else {
@@ -1 +1 @@
1
- {"version":3,"file":"method.js","sources":["../../../../../../../packages/components/src/plugins/confirmBox/method.ts"],"sourcesContent":["import { GmMessageBox } from '@giime/components/src/plugins/messageBox';\nexport interface ConfirmBoxOptions {\n message: string;\n title?: string;\n}\n\nexport const confirmBox = async (options: ConfirmBoxOptions, handle: () => Promise<any>) => {\n await GmMessageBox.confirm(options.message, options.title || '系统提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning',\n beforeClose: async (action, instance, done) => {\n if (action === 'confirm') {\n instance.confirmButtonLoading = true;\n try {\n await handle();\n done();\n } catch (e) {\n console.error(e);\n instance.confirmButtonLoading = false;\n }\n } else {\n done();\n }\n },\n });\n};\n"],"names":["GmMessageBox"],"mappings":";;;;AAMa,MAAA,UAAA,GAAa,OAAO,OAAA,EAA4B,MAA+B,KAAA;AAC1F,EAAA,MAAMA,mBAAa,OAAQ,CAAA,OAAA,CAAQ,OAAS,EAAA,OAAA,CAAQ,SAAS,0BAAQ,EAAA;AAAA,IACnE,iBAAmB,EAAA,cAAA;AAAA,IACnB,gBAAkB,EAAA,cAAA;AAAA,IAClB,IAAM,EAAA,SAAA;AAAA,IACN,WAAa,EAAA,OAAO,MAAQ,EAAA,QAAA,EAAU,IAAS,KAAA;AAC7C,MAAA,IAAI,WAAW,SAAW,EAAA;AACxB,QAAA,QAAA,CAAS,oBAAuB,GAAA,IAAA,CAAA;AAChC,QAAI,IAAA;AACF,UAAA,MAAM,MAAO,EAAA,CAAA;AACb,UAAK,IAAA,EAAA,CAAA;AAAA,iBACE,CAAG,EAAA;AACV,UAAA,OAAA,CAAQ,MAAM,CAAC,CAAA,CAAA;AACf,UAAA,QAAA,CAAS,oBAAuB,GAAA,KAAA,CAAA;AAAA,SAClC;AAAA,OACK,MAAA;AACL,QAAK,IAAA,EAAA,CAAA;AAAA,OACP;AAAA,KACF;AAAA,GACD,CAAA,CAAA;AACH;;;;"}
1
+ {"version":3,"file":"method.js","sources":["../../../../../../../packages/components/src/plugins/confirmBox/method.ts"],"sourcesContent":["import { GmMessageBox } from '@giime/components/src/plugins/messageBox';\nexport interface ConfirmBoxOptions {\n message: string;\n title?: string;\n}\n\nexport const confirmBox = async (options: ConfirmBoxOptions, handle?: () => Promise<any>) => {\n await GmMessageBox.confirm(options.message, options.title || '系统提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning',\n beforeClose: async (action, instance, done) => {\n if (action === 'confirm') {\n instance.confirmButtonLoading = true;\n try {\n await handle?.();\n done();\n instance.confirmButtonDisabled = true;\n } finally {\n instance.confirmButtonLoading = false;\n }\n } else {\n done();\n }\n },\n });\n};\n"],"names":["GmMessageBox"],"mappings":";;;;AAMa,MAAA,UAAA,GAAa,OAAO,OAAA,EAA4B,MAAgC,KAAA;AAC3F,EAAA,MAAMA,mBAAa,OAAQ,CAAA,OAAA,CAAQ,OAAS,EAAA,OAAA,CAAQ,SAAS,0BAAQ,EAAA;AAAA,IACnE,iBAAmB,EAAA,cAAA;AAAA,IACnB,gBAAkB,EAAA,cAAA;AAAA,IAClB,IAAM,EAAA,SAAA;AAAA,IACN,WAAa,EAAA,OAAO,MAAQ,EAAA,QAAA,EAAU,IAAS,KAAA;AAC7C,MAAA,IAAI,WAAW,SAAW,EAAA;AACxB,QAAA,QAAA,CAAS,oBAAuB,GAAA,IAAA,CAAA;AAChC,QAAI,IAAA;AACF,UAAA,MAAM,MAAS,IAAA,CAAA;AACf,UAAK,IAAA,EAAA,CAAA;AACL,UAAA,QAAA,CAAS,qBAAwB,GAAA,IAAA,CAAA;AAAA,SACjC,SAAA;AACA,UAAA,QAAA,CAAS,oBAAuB,GAAA,KAAA,CAAA;AAAA,SAClC;AAAA,OACK,MAAA;AACL,QAAK,IAAA,EAAA,CAAA;AAAA,OACP;AAAA,KACF;AAAA,GACD,CAAA,CAAA;AACH;;;;"}
@@ -1 +1 @@
1
- export declare const version = "0.6.39";
1
+ export declare const version = "0.6.41";
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- const version = "0.6.38";
3
+ const version = "0.6.40";
4
4
 
5
5
  exports.version = version;
6
6
  //# sourceMappingURL=version.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"version.js","sources":["../../../../packages/giime/version.ts"],"sourcesContent":["export const version = '0.6.38';\n"],"names":[],"mappings":";;AAAO,MAAM,OAAU,GAAA;;;;"}
1
+ {"version":3,"file":"version.js","sources":["../../../../packages/giime/version.ts"],"sourcesContent":["export const version = '0.6.40';\n"],"names":[],"mappings":";;AAAO,MAAM,OAAU,GAAA;;;;"}
package/lib/index.css CHANGED
@@ -959,11 +959,11 @@ video {
959
959
  margin: 0;
960
960
  }
961
961
 
962
- .gm-upload-pro-preview-dialog[data-v-ca99928c] [data-v-ca99928c] .el-dialog__body {
962
+ .gm-upload-pro-preview-dialog[data-v-c948a9bb] [data-v-c948a9bb] .el-dialog__body {
963
963
  padding: 0;
964
964
  }
965
965
 
966
- .gm-upload-pro-file-picture-card[data-v-ca99928c] [data-v-ca99928c] .el-upload-list__item, .gm-upload-pro-file-picture-card[data-v-ca99928c] [data-v-ca99928c] .el-upload--picture-card {
966
+ .gm-upload-pro-file-picture-card[data-v-c948a9bb] [data-v-c948a9bb] .el-upload-list__item, .gm-upload-pro-file-picture-card[data-v-c948a9bb] [data-v-c948a9bb] .el-upload--picture-card {
967
967
  width: auto;
968
968
  height: auto;
969
969
  }
@@ -114,7 +114,7 @@ const createExtensionRegex = (extensions) => {
114
114
  const isFileType = (url, type) => {
115
115
  if (!isString(url))
116
116
  return false;
117
- const baseUrl = url.split("?")[0].split("#")[0];
117
+ const baseUrl = url.split("?")[0];
118
118
  const regex = createExtensionRegex(FILE_EXTENSIONS[type]);
119
119
  return regex.test(baseUrl);
120
120
  };