@xiaou66/picture-plugin 0.0.36 → 0.0.37
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/index.cjs.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs.js","sources":["../src/storage/StoragePlugInConfig.ts","../src/utils/StrTemplateUtils.ts","../src/storage/StoragePlugIn.ts"],"sourcesContent":["export interface StorageUIFormElement {\n type: 'input' | 'input-format' | 'radio-group' | 'switch' | 'input-button';\n formItem: {\n rules?: Record<string, any>;\n field: string;\n label: string;\n [key: string]: any;\n },\n\n /**\n * 元素属性值\n */\n elementProperty: Record<string, any>;\n}\n\nexport interface StorageUIConfig {\n /**\n * 提示\n */\n tips: string,\n\n /**\n * 表单\n */\n forms: StorageUIFormElement[];\n}\n\n/**\n * 插件信息\n */\nexport interface PlugInfo {\n /**\n * 插件 code 全局唯一\n */\n pluginCode: string;\n /**\n * 插件名称\n */\n pluginName: string;\n\n /**\n * 插件版本\n */\n pluginVersion: string;\n\n /**\n * 插件作者\n */\n pluginAuthor: string;\n\n /**\n * 插件描述\n */\n pluginDesc: string;\n\n /**\n * 插件类型\n */\n pluginType: 'storage';\n\n /**\n * 插件 logo\n */\n pluginLogo: string;\n\n /**\n * 插件分组\n */\n pluginGroup: 'cloudVendor' | 'self' | 'other';\n}\nexport interface StoragePlugInConfig {\n\n /**\n * 无需配置可以直接使用\n */\n noConfig?: boolean;\n\n pluginInfo: PlugInfo;\n\n /**\n * 配置 ui\n */\n uiConfig?: StorageUIConfig;\n}\n\n/**\n * 场景插件配置\n * @param config\n */\nexport function createStoragePlugInConfig(config: Omit<StoragePlugInConfig, 'pluginInfo'> & { pluginInfo: Omit<PlugInfo, 'pluginType'> }): StoragePlugInConfig {\n const newConfig = config as StoragePlugInConfig\n newConfig.pluginInfo.pluginType = 'storage';\n return newConfig;\n}\n","import { IUploadFileParams } from '../storage'\n\n\nexport const stringVariable = [\n {\n label: '年',\n value: '{YY}',\n demo: () => {\n return new Date().getFullYear().toString();\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getFullYear().toString();\n }\n },\n {\n label: '年',\n value: '{Y}',\n demo: () => {\n return new Date().getFullYear().toString().substring(2);\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getFullYear().toString().substring(2);\n }\n },\n {\n label: '月',\n value: '{M}',\n demo: () => {\n return (new Date().getMonth() + 1).toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return (new Date().getMonth() + 1).toString().padStart(2, '0');\n }\n },\n {\n label: '日',\n value: '{D}',\n demo: () => {\n return (new Date().getDate()).toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return (new Date().getDate()).toString().padStart(2, '0');\n }\n },\n {\n label: '时',\n value: '{h}',\n demo: () => {\n return new Date().getHours().toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getHours().toString().padStart(2, '0');\n }\n },\n {\n label: '分',\n value: '{m}',\n demo: () => {\n return new Date().getMinutes().toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getMinutes().toString().padStart(2, '0');\n }\n },\n {\n label: '秒',\n value: '{s}',\n demo: () => {\n return new Date().getSeconds().toString().padStart(2, '0');\n },\n format: () => {\n return new Date().getSeconds().toString().padStart(2, '0');\n }\n },\n {\n label: '毫秒',\n value: '{ss}',\n demo: () => {\n return new Date().getMilliseconds().toString().padStart(3, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getMilliseconds().toString().padStart(3, '0');\n }\n },\n {\n label: '时间戳',\n value: '{timestamp}',\n width: 300,\n demo: () => {\n return Date.now();\n },\n format: (obj: IUploadFileParams) => {\n return Date.now().toString();\n }\n },\n {\n label: '文件名称',\n value: '{filename}',\n width: 200,\n demo: () => {\n return '文本';\n },\n format: (obj: IUploadFileParams) => {\n return obj.fileName;\n }\n },\n {\n label: '后缀',\n value: '{suffix}',\n width: 200,\n demo: () => {\n return 'txt';\n },\n format: (obj: IUploadFileParams) => {\n return obj.suffix;\n }\n },\n {\n label: '全文件名',\n value: '{allFilename}',\n width: 300,\n demo: () => {\n return '文本.txt';\n },\n format: (obj: IUploadFileParams) => {\n return obj.allFileName;\n }\n },\n {\n label: '场景名称',\n value: '{sceneName}',\n width: 300,\n demo: () => {\n return '测试场景';\n },\n format: (obj: IUploadFileParams) => {\n return obj.sceneName || '';\n }\n },\n {\n label: '随机字符串',\n value: '{rand(5)}',\n width: 300,\n demo: () => {\n return generateRandomString(5);\n },\n format: (obj: IUploadFileParams) => {\n return generateRandomString(5);\n }\n },\n];\n\n// 生成指定长度的随机字符串\nfunction generateRandomString(length: number): string {\n const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n let result = '';\n for (let i = 0; i < length; i++) {\n result += chars.charAt(Math.floor(Math.random() * chars.length));\n }\n return result;\n}\nexport function filePathFormat(str: string, obj: IUploadFileParams): string {\n console.log('filePathFormat', str, obj)\n stringVariable.forEach(variable => {\n // 获取变量的值\n const value = variable.format(obj) || '';\n // 使用正则表达式替换所有匹配的变量\n const regex = new RegExp(variable.value, 'g'); // 'g' 标志表示全局替换\n str = str.replace(regex, value);\n });\n\n // 处理动态变量 {rand(n)}\n const randRegex = /\\{rand\\((\\d+)\\)\\}/g;\n str = str.replace(randRegex, (match, p1) => {\n const length = parseInt(p1, 10);\n return generateRandomString(length);\n });\n\n return str;\n}\n","import { IDeleteFileParams, IUploadFileParams, IUploadFileResult } from './StoragePlugInType'\nimport { filePathFormat } from '../utils'\n\n\n/**\n * 插件接口\n */\ninterface IStoragePlugIn {\n\n /**\n * 插件初始化调用\n */\n init(errorCallback: ErrorCallbackType): void;\n\n /**\n * 插件销毁调用\n */\n destroy(): void;\n}\n\n\ntype ErrorCallbackType = (name: string, action: string, error: Error) => void;\n\n\n/**\n * 存储插件\n */\nexport abstract class StoragePlugIn<C = any, E = any> implements IStoragePlugIn {\n\n init(): void {\n this.doInit()\n }\n\n /**\n * 初始化使用 <br/>\n * constructor 方法之后调用, 在第一次使用前调用\n * @protected\n */\n protected abstract doInit(): void\n\n destroy() {\n this.doDestroy()\n }\n\n /**\n * 插件销毁调用, 用于销毁资源\n * @protected\n */\n protected abstract doDestroy(): void\n\n\n /**\n * 上传文件\n * @param params 参数\n */\n abstract uploadFile(params: IUploadFileParams): Promise<IUploadFileResult<E>>\n\n\n /**\n * 删除文件 <br/>\n * 如果要实现删除文件请实现这个接口\n * @param params 参数\n */\n public deleteFile(params: IDeleteFileParams<E>): Promise<boolean> {\n return Promise.resolve(false);\n }\n\n /**\n * 格式化上传路径\n * @param templateStr 模版路径\n * @param params 上传参数\n * @protected\n */\n protected formatUploadPath(templateStr: string, params: IUploadFileParams) {\n return filePathFormat(templateStr, params);\n }\n\n /**\n * 从 URL 中提取路径\n * @param url 完整的图片 URL\n * @returns 图片路径\n */\n protected extractImagePath(url: string): string {\n try {\n const urlObj = new URL(url);\n return urlObj.pathname;\n } catch (error) {\n // 如果 URL 解析失败,尝试使用正则表达式\n const matches = url.match(/https?:\\/\\/[^\\/]+(\\/.*)/);\n return matches ? matches[1] : '';\n }\n }\n\n\n /**\n * 校验配置 <br/>\n * 如果不通过抛出异常\n * @param config\n * @protected\n */\n public verifyConfig(config: C): Promise<void> {\n return Promise.resolve(undefined);\n }\n\n protected readConfig(storageId: string): C {\n const key = `storageSource/${storageId}`\n return utools.dbCryptoStorage.getItem(key)\n }\n\n protected saveConfig(storageId: string, config: C): void {\n const key = `storageSource/${storageId}`;\n utools.dbCryptoStorage.setItem(key, config);\n }\n\n /**\n * 插件被卸载\n */\n uninstall() {\n\n }\n}\n"],"names":["createStoragePlugInConfig","config","newConfig","stringVariable","obj","generateRandomString","length","chars","result","i","filePathFormat","str","variable","value","regex","randRegex","match","p1","StoragePlugIn","params","templateStr","url","matches","storageId","key"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.cjs.js","sources":["../src/storage/StoragePlugInConfig.ts","../src/utils/StrTemplateUtils.ts","../src/storage/StoragePlugIn.ts"],"sourcesContent":["import { AsyncComponentLoader, AsyncComponentOptions } from '@vue'\n\nexport interface StorageUIFormElement {\n type: 'input' | 'input-format' | 'radio-group' | 'switch' | 'input-button' | 'select' | 'custom';\n customComponent?: AsyncComponentLoader | AsyncComponentOptions;\n formItem: {\n rules?: Record<string, any>;\n field: string;\n label: string;\n [key: string]: any;\n },\n\n /**\n * 元素属性值\n */\n elementProperty: Record<string, any>;\n /**\n * 元素事件\n */\n elementEvent?: Record<string, any>;\n}\n\nexport interface StorageUIConfig {\n /**\n * 提示\n */\n tips: string,\n\n /**\n * 表单\n */\n forms: StorageUIFormElement[];\n}\n\n/**\n * 插件信息\n */\nexport interface PlugInfo {\n /**\n * 插件 code 全局唯一\n */\n pluginCode: string;\n /**\n * 插件名称\n */\n pluginName: string;\n\n /**\n * 插件版本\n */\n pluginVersion: string;\n\n /**\n * 插件作者\n */\n pluginAuthor: string;\n\n /**\n * 插件描述\n */\n pluginDesc: string;\n\n /**\n * 插件类型\n */\n pluginType: 'storage';\n\n /**\n * 插件 logo\n */\n pluginLogo: string;\n\n /**\n * 插件分组\n */\n pluginGroup: 'cloudVendor' | 'self' | 'other';\n}\nexport interface StoragePlugInConfig {\n\n /**\n * 无需配置可以直接使用\n */\n noConfig?: boolean;\n\n pluginInfo: PlugInfo;\n\n /**\n * 配置 ui\n */\n uiConfig?: StorageUIConfig;\n}\n\n/**\n * 场景插件配置\n * @param config\n */\nexport function createStoragePlugInConfig(config: Omit<StoragePlugInConfig, 'pluginInfo'> & { pluginInfo: Omit<PlugInfo, 'pluginType'> }): StoragePlugInConfig {\n const newConfig = config as StoragePlugInConfig\n newConfig.pluginInfo.pluginType = 'storage';\n return newConfig;\n}\n","import { IUploadFileParams } from '../storage'\n\n\nexport const stringVariable = [\n {\n label: '年',\n value: '{YY}',\n demo: () => {\n return new Date().getFullYear().toString();\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getFullYear().toString();\n }\n },\n {\n label: '年',\n value: '{Y}',\n demo: () => {\n return new Date().getFullYear().toString().substring(2);\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getFullYear().toString().substring(2);\n }\n },\n {\n label: '月',\n value: '{M}',\n demo: () => {\n return (new Date().getMonth() + 1).toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return (new Date().getMonth() + 1).toString().padStart(2, '0');\n }\n },\n {\n label: '日',\n value: '{D}',\n demo: () => {\n return (new Date().getDate()).toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return (new Date().getDate()).toString().padStart(2, '0');\n }\n },\n {\n label: '时',\n value: '{h}',\n demo: () => {\n return new Date().getHours().toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getHours().toString().padStart(2, '0');\n }\n },\n {\n label: '分',\n value: '{m}',\n demo: () => {\n return new Date().getMinutes().toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getMinutes().toString().padStart(2, '0');\n }\n },\n {\n label: '秒',\n value: '{s}',\n demo: () => {\n return new Date().getSeconds().toString().padStart(2, '0');\n },\n format: () => {\n return new Date().getSeconds().toString().padStart(2, '0');\n }\n },\n {\n label: '毫秒',\n value: '{ss}',\n demo: () => {\n return new Date().getMilliseconds().toString().padStart(3, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getMilliseconds().toString().padStart(3, '0');\n }\n },\n {\n label: '时间戳',\n value: '{timestamp}',\n width: 300,\n demo: () => {\n return Date.now();\n },\n format: (obj: IUploadFileParams) => {\n return Date.now().toString();\n }\n },\n {\n label: '文件名称',\n value: '{filename}',\n width: 200,\n demo: () => {\n return '文本';\n },\n format: (obj: IUploadFileParams) => {\n return obj.fileName;\n }\n },\n {\n label: '后缀',\n value: '{suffix}',\n width: 200,\n demo: () => {\n return 'txt';\n },\n format: (obj: IUploadFileParams) => {\n return obj.suffix;\n }\n },\n {\n label: '全文件名',\n value: '{allFilename}',\n width: 300,\n demo: () => {\n return '文本.txt';\n },\n format: (obj: IUploadFileParams) => {\n return obj.allFileName;\n }\n },\n {\n label: '场景名称',\n value: '{sceneName}',\n width: 300,\n demo: () => {\n return '测试场景';\n },\n format: (obj: IUploadFileParams) => {\n return obj.sceneName || '';\n }\n },\n {\n label: '随机字符串',\n value: '{rand(5)}',\n width: 300,\n demo: () => {\n return generateRandomString(5);\n },\n format: (obj: IUploadFileParams) => {\n return generateRandomString(5);\n }\n },\n];\n\n// 生成指定长度的随机字符串\nfunction generateRandomString(length: number): string {\n const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n let result = '';\n for (let i = 0; i < length; i++) {\n result += chars.charAt(Math.floor(Math.random() * chars.length));\n }\n return result;\n}\nexport function filePathFormat(str: string, obj: IUploadFileParams): string {\n console.log('filePathFormat', str, obj)\n stringVariable.forEach(variable => {\n // 获取变量的值\n const value = variable.format(obj) || '';\n // 使用正则表达式替换所有匹配的变量\n const regex = new RegExp(variable.value, 'g'); // 'g' 标志表示全局替换\n str = str.replace(regex, value);\n });\n\n // 处理动态变量 {rand(n)}\n const randRegex = /\\{rand\\((\\d+)\\)\\}/g;\n str = str.replace(randRegex, (match, p1) => {\n const length = parseInt(p1, 10);\n return generateRandomString(length);\n });\n\n return str;\n}\n","import { IDeleteFileParams, IUploadFileParams, IUploadFileResult } from './StoragePlugInType'\nimport { filePathFormat } from '../utils'\n\n\n/**\n * 插件接口\n */\ninterface IStoragePlugIn {\n\n /**\n * 插件初始化调用\n */\n init(errorCallback: ErrorCallbackType): void;\n\n /**\n * 插件销毁调用\n */\n destroy(): void;\n}\n\n\ntype ErrorCallbackType = (name: string, action: string, error: Error) => void;\n\n\n/**\n * 存储插件\n */\nexport abstract class StoragePlugIn<C = any, E = any> implements IStoragePlugIn {\n\n init(): void {\n this.doInit()\n }\n\n /**\n * 初始化使用 <br/>\n * constructor 方法之后调用, 在第一次使用前调用\n * @protected\n */\n protected abstract doInit(): void\n\n destroy() {\n this.doDestroy()\n }\n\n /**\n * 插件销毁调用, 用于销毁资源\n * @protected\n */\n protected abstract doDestroy(): void\n\n\n /**\n * 上传文件\n * @param params 参数\n */\n abstract uploadFile(params: IUploadFileParams): Promise<IUploadFileResult<E>>\n\n\n /**\n * 删除文件 <br/>\n * 如果要实现删除文件请实现这个接口\n * @param params 参数\n */\n public deleteFile(params: IDeleteFileParams<E>): Promise<boolean> {\n return Promise.resolve(false);\n }\n\n /**\n * 格式化上传路径\n * @param templateStr 模版路径\n * @param params 上传参数\n * @protected\n */\n protected formatUploadPath(templateStr: string, params: IUploadFileParams) {\n return filePathFormat(templateStr, params);\n }\n\n /**\n * 从 URL 中提取路径\n * @param url 完整的图片 URL\n * @returns 图片路径\n */\n protected extractImagePath(url: string): string {\n try {\n const urlObj = new URL(url);\n return urlObj.pathname;\n } catch (error) {\n // 如果 URL 解析失败,尝试使用正则表达式\n const matches = url.match(/https?:\\/\\/[^\\/]+(\\/.*)/);\n return matches ? matches[1] : '';\n }\n }\n\n\n /**\n * 校验配置 <br/>\n * 如果不通过抛出异常\n * @param config\n * @protected\n */\n public verifyConfig(config: C): Promise<void> {\n return Promise.resolve(undefined);\n }\n\n protected readConfig(storageId: string): C {\n const key = `storageSource/${storageId}`\n return utools.dbCryptoStorage.getItem(key)\n }\n\n protected saveConfig(storageId: string, config: C): void {\n const key = `storageSource/${storageId}`;\n utools.dbCryptoStorage.setItem(key, config);\n }\n\n /**\n * 插件被卸载\n */\n uninstall() {\n\n }\n}\n"],"names":["createStoragePlugInConfig","config","newConfig","stringVariable","obj","generateRandomString","length","chars","result","i","filePathFormat","str","variable","value","regex","randRegex","match","p1","StoragePlugIn","params","templateStr","url","matches","storageId","key"],"mappings":"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"}
|
package/dist/index.es.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.es.js","sources":["../src/storage/StoragePlugInConfig.ts","../src/utils/StrTemplateUtils.ts","../src/storage/StoragePlugIn.ts"],"sourcesContent":["export interface StorageUIFormElement {\n type: 'input' | 'input-format' | 'radio-group' | 'switch' | 'input-button';\n formItem: {\n rules?: Record<string, any>;\n field: string;\n label: string;\n [key: string]: any;\n },\n\n /**\n * 元素属性值\n */\n elementProperty: Record<string, any>;\n}\n\nexport interface StorageUIConfig {\n /**\n * 提示\n */\n tips: string,\n\n /**\n * 表单\n */\n forms: StorageUIFormElement[];\n}\n\n/**\n * 插件信息\n */\nexport interface PlugInfo {\n /**\n * 插件 code 全局唯一\n */\n pluginCode: string;\n /**\n * 插件名称\n */\n pluginName: string;\n\n /**\n * 插件版本\n */\n pluginVersion: string;\n\n /**\n * 插件作者\n */\n pluginAuthor: string;\n\n /**\n * 插件描述\n */\n pluginDesc: string;\n\n /**\n * 插件类型\n */\n pluginType: 'storage';\n\n /**\n * 插件 logo\n */\n pluginLogo: string;\n\n /**\n * 插件分组\n */\n pluginGroup: 'cloudVendor' | 'self' | 'other';\n}\nexport interface StoragePlugInConfig {\n\n /**\n * 无需配置可以直接使用\n */\n noConfig?: boolean;\n\n pluginInfo: PlugInfo;\n\n /**\n * 配置 ui\n */\n uiConfig?: StorageUIConfig;\n}\n\n/**\n * 场景插件配置\n * @param config\n */\nexport function createStoragePlugInConfig(config: Omit<StoragePlugInConfig, 'pluginInfo'> & { pluginInfo: Omit<PlugInfo, 'pluginType'> }): StoragePlugInConfig {\n const newConfig = config as StoragePlugInConfig\n newConfig.pluginInfo.pluginType = 'storage';\n return newConfig;\n}\n","import { IUploadFileParams } from '../storage'\n\n\nexport const stringVariable = [\n {\n label: '年',\n value: '{YY}',\n demo: () => {\n return new Date().getFullYear().toString();\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getFullYear().toString();\n }\n },\n {\n label: '年',\n value: '{Y}',\n demo: () => {\n return new Date().getFullYear().toString().substring(2);\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getFullYear().toString().substring(2);\n }\n },\n {\n label: '月',\n value: '{M}',\n demo: () => {\n return (new Date().getMonth() + 1).toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return (new Date().getMonth() + 1).toString().padStart(2, '0');\n }\n },\n {\n label: '日',\n value: '{D}',\n demo: () => {\n return (new Date().getDate()).toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return (new Date().getDate()).toString().padStart(2, '0');\n }\n },\n {\n label: '时',\n value: '{h}',\n demo: () => {\n return new Date().getHours().toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getHours().toString().padStart(2, '0');\n }\n },\n {\n label: '分',\n value: '{m}',\n demo: () => {\n return new Date().getMinutes().toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getMinutes().toString().padStart(2, '0');\n }\n },\n {\n label: '秒',\n value: '{s}',\n demo: () => {\n return new Date().getSeconds().toString().padStart(2, '0');\n },\n format: () => {\n return new Date().getSeconds().toString().padStart(2, '0');\n }\n },\n {\n label: '毫秒',\n value: '{ss}',\n demo: () => {\n return new Date().getMilliseconds().toString().padStart(3, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getMilliseconds().toString().padStart(3, '0');\n }\n },\n {\n label: '时间戳',\n value: '{timestamp}',\n width: 300,\n demo: () => {\n return Date.now();\n },\n format: (obj: IUploadFileParams) => {\n return Date.now().toString();\n }\n },\n {\n label: '文件名称',\n value: '{filename}',\n width: 200,\n demo: () => {\n return '文本';\n },\n format: (obj: IUploadFileParams) => {\n return obj.fileName;\n }\n },\n {\n label: '后缀',\n value: '{suffix}',\n width: 200,\n demo: () => {\n return 'txt';\n },\n format: (obj: IUploadFileParams) => {\n return obj.suffix;\n }\n },\n {\n label: '全文件名',\n value: '{allFilename}',\n width: 300,\n demo: () => {\n return '文本.txt';\n },\n format: (obj: IUploadFileParams) => {\n return obj.allFileName;\n }\n },\n {\n label: '场景名称',\n value: '{sceneName}',\n width: 300,\n demo: () => {\n return '测试场景';\n },\n format: (obj: IUploadFileParams) => {\n return obj.sceneName || '';\n }\n },\n {\n label: '随机字符串',\n value: '{rand(5)}',\n width: 300,\n demo: () => {\n return generateRandomString(5);\n },\n format: (obj: IUploadFileParams) => {\n return generateRandomString(5);\n }\n },\n];\n\n// 生成指定长度的随机字符串\nfunction generateRandomString(length: number): string {\n const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n let result = '';\n for (let i = 0; i < length; i++) {\n result += chars.charAt(Math.floor(Math.random() * chars.length));\n }\n return result;\n}\nexport function filePathFormat(str: string, obj: IUploadFileParams): string {\n console.log('filePathFormat', str, obj)\n stringVariable.forEach(variable => {\n // 获取变量的值\n const value = variable.format(obj) || '';\n // 使用正则表达式替换所有匹配的变量\n const regex = new RegExp(variable.value, 'g'); // 'g' 标志表示全局替换\n str = str.replace(regex, value);\n });\n\n // 处理动态变量 {rand(n)}\n const randRegex = /\\{rand\\((\\d+)\\)\\}/g;\n str = str.replace(randRegex, (match, p1) => {\n const length = parseInt(p1, 10);\n return generateRandomString(length);\n });\n\n return str;\n}\n","import { IDeleteFileParams, IUploadFileParams, IUploadFileResult } from './StoragePlugInType'\nimport { filePathFormat } from '../utils'\n\n\n/**\n * 插件接口\n */\ninterface IStoragePlugIn {\n\n /**\n * 插件初始化调用\n */\n init(errorCallback: ErrorCallbackType): void;\n\n /**\n * 插件销毁调用\n */\n destroy(): void;\n}\n\n\ntype ErrorCallbackType = (name: string, action: string, error: Error) => void;\n\n\n/**\n * 存储插件\n */\nexport abstract class StoragePlugIn<C = any, E = any> implements IStoragePlugIn {\n\n init(): void {\n this.doInit()\n }\n\n /**\n * 初始化使用 <br/>\n * constructor 方法之后调用, 在第一次使用前调用\n * @protected\n */\n protected abstract doInit(): void\n\n destroy() {\n this.doDestroy()\n }\n\n /**\n * 插件销毁调用, 用于销毁资源\n * @protected\n */\n protected abstract doDestroy(): void\n\n\n /**\n * 上传文件\n * @param params 参数\n */\n abstract uploadFile(params: IUploadFileParams): Promise<IUploadFileResult<E>>\n\n\n /**\n * 删除文件 <br/>\n * 如果要实现删除文件请实现这个接口\n * @param params 参数\n */\n public deleteFile(params: IDeleteFileParams<E>): Promise<boolean> {\n return Promise.resolve(false);\n }\n\n /**\n * 格式化上传路径\n * @param templateStr 模版路径\n * @param params 上传参数\n * @protected\n */\n protected formatUploadPath(templateStr: string, params: IUploadFileParams) {\n return filePathFormat(templateStr, params);\n }\n\n /**\n * 从 URL 中提取路径\n * @param url 完整的图片 URL\n * @returns 图片路径\n */\n protected extractImagePath(url: string): string {\n try {\n const urlObj = new URL(url);\n return urlObj.pathname;\n } catch (error) {\n // 如果 URL 解析失败,尝试使用正则表达式\n const matches = url.match(/https?:\\/\\/[^\\/]+(\\/.*)/);\n return matches ? matches[1] : '';\n }\n }\n\n\n /**\n * 校验配置 <br/>\n * 如果不通过抛出异常\n * @param config\n * @protected\n */\n public verifyConfig(config: C): Promise<void> {\n return Promise.resolve(undefined);\n }\n\n protected readConfig(storageId: string): C {\n const key = `storageSource/${storageId}`\n return utools.dbCryptoStorage.getItem(key)\n }\n\n protected saveConfig(storageId: string, config: C): void {\n const key = `storageSource/${storageId}`;\n utools.dbCryptoStorage.setItem(key, config);\n }\n\n /**\n * 插件被卸载\n */\n uninstall() {\n\n }\n}\n"],"names":["createStoragePlugInConfig","config","newConfig","stringVariable","obj","generateRandomString","length","chars","result","i","filePathFormat","str","variable","value","regex","randRegex","match","p1","StoragePlugIn","params","templateStr","url","matches","storageId","key"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.es.js","sources":["../src/storage/StoragePlugInConfig.ts","../src/utils/StrTemplateUtils.ts","../src/storage/StoragePlugIn.ts"],"sourcesContent":["import { AsyncComponentLoader, AsyncComponentOptions } from '@vue'\n\nexport interface StorageUIFormElement {\n type: 'input' | 'input-format' | 'radio-group' | 'switch' | 'input-button' | 'select' | 'custom';\n customComponent?: AsyncComponentLoader | AsyncComponentOptions;\n formItem: {\n rules?: Record<string, any>;\n field: string;\n label: string;\n [key: string]: any;\n },\n\n /**\n * 元素属性值\n */\n elementProperty: Record<string, any>;\n /**\n * 元素事件\n */\n elementEvent?: Record<string, any>;\n}\n\nexport interface StorageUIConfig {\n /**\n * 提示\n */\n tips: string,\n\n /**\n * 表单\n */\n forms: StorageUIFormElement[];\n}\n\n/**\n * 插件信息\n */\nexport interface PlugInfo {\n /**\n * 插件 code 全局唯一\n */\n pluginCode: string;\n /**\n * 插件名称\n */\n pluginName: string;\n\n /**\n * 插件版本\n */\n pluginVersion: string;\n\n /**\n * 插件作者\n */\n pluginAuthor: string;\n\n /**\n * 插件描述\n */\n pluginDesc: string;\n\n /**\n * 插件类型\n */\n pluginType: 'storage';\n\n /**\n * 插件 logo\n */\n pluginLogo: string;\n\n /**\n * 插件分组\n */\n pluginGroup: 'cloudVendor' | 'self' | 'other';\n}\nexport interface StoragePlugInConfig {\n\n /**\n * 无需配置可以直接使用\n */\n noConfig?: boolean;\n\n pluginInfo: PlugInfo;\n\n /**\n * 配置 ui\n */\n uiConfig?: StorageUIConfig;\n}\n\n/**\n * 场景插件配置\n * @param config\n */\nexport function createStoragePlugInConfig(config: Omit<StoragePlugInConfig, 'pluginInfo'> & { pluginInfo: Omit<PlugInfo, 'pluginType'> }): StoragePlugInConfig {\n const newConfig = config as StoragePlugInConfig\n newConfig.pluginInfo.pluginType = 'storage';\n return newConfig;\n}\n","import { IUploadFileParams } from '../storage'\n\n\nexport const stringVariable = [\n {\n label: '年',\n value: '{YY}',\n demo: () => {\n return new Date().getFullYear().toString();\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getFullYear().toString();\n }\n },\n {\n label: '年',\n value: '{Y}',\n demo: () => {\n return new Date().getFullYear().toString().substring(2);\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getFullYear().toString().substring(2);\n }\n },\n {\n label: '月',\n value: '{M}',\n demo: () => {\n return (new Date().getMonth() + 1).toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return (new Date().getMonth() + 1).toString().padStart(2, '0');\n }\n },\n {\n label: '日',\n value: '{D}',\n demo: () => {\n return (new Date().getDate()).toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return (new Date().getDate()).toString().padStart(2, '0');\n }\n },\n {\n label: '时',\n value: '{h}',\n demo: () => {\n return new Date().getHours().toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getHours().toString().padStart(2, '0');\n }\n },\n {\n label: '分',\n value: '{m}',\n demo: () => {\n return new Date().getMinutes().toString().padStart(2, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getMinutes().toString().padStart(2, '0');\n }\n },\n {\n label: '秒',\n value: '{s}',\n demo: () => {\n return new Date().getSeconds().toString().padStart(2, '0');\n },\n format: () => {\n return new Date().getSeconds().toString().padStart(2, '0');\n }\n },\n {\n label: '毫秒',\n value: '{ss}',\n demo: () => {\n return new Date().getMilliseconds().toString().padStart(3, '0');\n },\n format: (obj: IUploadFileParams) => {\n return new Date().getMilliseconds().toString().padStart(3, '0');\n }\n },\n {\n label: '时间戳',\n value: '{timestamp}',\n width: 300,\n demo: () => {\n return Date.now();\n },\n format: (obj: IUploadFileParams) => {\n return Date.now().toString();\n }\n },\n {\n label: '文件名称',\n value: '{filename}',\n width: 200,\n demo: () => {\n return '文本';\n },\n format: (obj: IUploadFileParams) => {\n return obj.fileName;\n }\n },\n {\n label: '后缀',\n value: '{suffix}',\n width: 200,\n demo: () => {\n return 'txt';\n },\n format: (obj: IUploadFileParams) => {\n return obj.suffix;\n }\n },\n {\n label: '全文件名',\n value: '{allFilename}',\n width: 300,\n demo: () => {\n return '文本.txt';\n },\n format: (obj: IUploadFileParams) => {\n return obj.allFileName;\n }\n },\n {\n label: '场景名称',\n value: '{sceneName}',\n width: 300,\n demo: () => {\n return '测试场景';\n },\n format: (obj: IUploadFileParams) => {\n return obj.sceneName || '';\n }\n },\n {\n label: '随机字符串',\n value: '{rand(5)}',\n width: 300,\n demo: () => {\n return generateRandomString(5);\n },\n format: (obj: IUploadFileParams) => {\n return generateRandomString(5);\n }\n },\n];\n\n// 生成指定长度的随机字符串\nfunction generateRandomString(length: number): string {\n const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n let result = '';\n for (let i = 0; i < length; i++) {\n result += chars.charAt(Math.floor(Math.random() * chars.length));\n }\n return result;\n}\nexport function filePathFormat(str: string, obj: IUploadFileParams): string {\n console.log('filePathFormat', str, obj)\n stringVariable.forEach(variable => {\n // 获取变量的值\n const value = variable.format(obj) || '';\n // 使用正则表达式替换所有匹配的变量\n const regex = new RegExp(variable.value, 'g'); // 'g' 标志表示全局替换\n str = str.replace(regex, value);\n });\n\n // 处理动态变量 {rand(n)}\n const randRegex = /\\{rand\\((\\d+)\\)\\}/g;\n str = str.replace(randRegex, (match, p1) => {\n const length = parseInt(p1, 10);\n return generateRandomString(length);\n });\n\n return str;\n}\n","import { IDeleteFileParams, IUploadFileParams, IUploadFileResult } from './StoragePlugInType'\nimport { filePathFormat } from '../utils'\n\n\n/**\n * 插件接口\n */\ninterface IStoragePlugIn {\n\n /**\n * 插件初始化调用\n */\n init(errorCallback: ErrorCallbackType): void;\n\n /**\n * 插件销毁调用\n */\n destroy(): void;\n}\n\n\ntype ErrorCallbackType = (name: string, action: string, error: Error) => void;\n\n\n/**\n * 存储插件\n */\nexport abstract class StoragePlugIn<C = any, E = any> implements IStoragePlugIn {\n\n init(): void {\n this.doInit()\n }\n\n /**\n * 初始化使用 <br/>\n * constructor 方法之后调用, 在第一次使用前调用\n * @protected\n */\n protected abstract doInit(): void\n\n destroy() {\n this.doDestroy()\n }\n\n /**\n * 插件销毁调用, 用于销毁资源\n * @protected\n */\n protected abstract doDestroy(): void\n\n\n /**\n * 上传文件\n * @param params 参数\n */\n abstract uploadFile(params: IUploadFileParams): Promise<IUploadFileResult<E>>\n\n\n /**\n * 删除文件 <br/>\n * 如果要实现删除文件请实现这个接口\n * @param params 参数\n */\n public deleteFile(params: IDeleteFileParams<E>): Promise<boolean> {\n return Promise.resolve(false);\n }\n\n /**\n * 格式化上传路径\n * @param templateStr 模版路径\n * @param params 上传参数\n * @protected\n */\n protected formatUploadPath(templateStr: string, params: IUploadFileParams) {\n return filePathFormat(templateStr, params);\n }\n\n /**\n * 从 URL 中提取路径\n * @param url 完整的图片 URL\n * @returns 图片路径\n */\n protected extractImagePath(url: string): string {\n try {\n const urlObj = new URL(url);\n return urlObj.pathname;\n } catch (error) {\n // 如果 URL 解析失败,尝试使用正则表达式\n const matches = url.match(/https?:\\/\\/[^\\/]+(\\/.*)/);\n return matches ? matches[1] : '';\n }\n }\n\n\n /**\n * 校验配置 <br/>\n * 如果不通过抛出异常\n * @param config\n * @protected\n */\n public verifyConfig(config: C): Promise<void> {\n return Promise.resolve(undefined);\n }\n\n protected readConfig(storageId: string): C {\n const key = `storageSource/${storageId}`\n return utools.dbCryptoStorage.getItem(key)\n }\n\n protected saveConfig(storageId: string, config: C): void {\n const key = `storageSource/${storageId}`;\n utools.dbCryptoStorage.setItem(key, config);\n }\n\n /**\n * 插件被卸载\n */\n uninstall() {\n\n }\n}\n"],"names":["createStoragePlugInConfig","config","newConfig","stringVariable","obj","generateRandomString","length","chars","result","i","filePathFormat","str","variable","value","regex","randRegex","match","p1","StoragePlugIn","params","templateStr","url","matches","storageId","key"],"mappings":"AAgGO,SAASA,EAA0BC,GAAqH;AAC7J,QAAMC,IAAYD;AAClB,SAAAC,EAAU,WAAW,aAAa,WAC3BA;AACT;ACjGO,MAAMC,IAAiB;AAAA,EAC5B;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,OACO,oBAAA,KAAA,GAAO,YAAA,EAAc,SAAS;AAAA,IAE3C,QAAQ,CAACC,OACI,oBAAA,KAAA,GAAO,YAAA,EAAc,SAAS;AAAA,EAE7C;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,OACG,oBAAI,QAAO,cAAc,SAAS,EAAE,UAAU,CAAC;AAAA,IAExD,QAAQ,CAACA,OACA,oBAAI,QAAO,cAAc,SAAS,EAAE,UAAU,CAAC;AAAA,EAE1D;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,QACI,oBAAI,KAAK,GAAE,SAAS,IAAI,GAAG,WAAW,SAAS,GAAG,GAAG;AAAA,IAE/D,QAAQ,CAACA,QACC,oBAAI,KAAK,GAAE,SAAS,IAAI,GAAG,WAAW,SAAS,GAAG,GAAG;AAAA,EAEjE;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,OACI,oBAAI,QAAO,QAAA,EAAW,WAAW,SAAS,GAAG,GAAG;AAAA,IAE1D,QAAQ,CAACA,OACC,oBAAI,QAAO,QAAA,EAAW,WAAW,SAAS,GAAG,GAAG;AAAA,EAE5D;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,OACG,oBAAI,QAAO,SAAA,EAAW,WAAW,SAAS,GAAG,GAAG;AAAA,IAEzD,QAAQ,CAACA,OACA,oBAAI,QAAO,SAAA,EAAW,WAAW,SAAS,GAAG,GAAG;AAAA,EAE3D;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,OACG,oBAAI,QAAO,WAAA,EAAa,WAAW,SAAS,GAAG,GAAG;AAAA,IAE3D,QAAQ,CAACA,OACA,oBAAI,QAAO,WAAA,EAAa,WAAW,SAAS,GAAG,GAAG;AAAA,EAE7D;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,OACG,oBAAI,QAAO,WAAA,EAAa,WAAW,SAAS,GAAG,GAAG;AAAA,IAE3D,QAAQ,OACC,oBAAI,QAAO,WAAA,EAAa,WAAW,SAAS,GAAG,GAAG;AAAA,EAE7D;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,OACG,oBAAI,QAAO,gBAAA,EAAkB,WAAW,SAAS,GAAG,GAAG;AAAA,IAEhE,QAAQ,CAACA,OACA,oBAAI,QAAO,gBAAA,EAAkB,WAAW,SAAS,GAAG,GAAG;AAAA,EAElE;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,MACG,KAAK,IAAI;AAAA,IAElB,QAAQ,CAACA,MACA,KAAK,IAAI,EAAE,SAAS;AAAA,EAE/B;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,MACG;AAAA,IAET,QAAQ,CAACA,MACAA,EAAI;AAAA,EAEf;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,MACG;AAAA,IAET,QAAQ,CAACA,MACAA,EAAI;AAAA,EAEf;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,MACG;AAAA,IAET,QAAQ,CAACA,MACAA,EAAI;AAAA,EAEf;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,MACG;AAAA,IAET,QAAQ,CAACA,MACAA,EAAI,aAAa;AAAA,EAE5B;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,IACP,OAAO;AAAA,IACP,MAAM,MACGC,EAAqB,CAAC;AAAA,IAE/B,QAAQ,CAACD,MACAC,EAAqB,CAAC;AAAA,EAC/B;AAEJ;AAGA,SAASA,EAAqBC,GAAwB;AACpD,QAAMC,IAAQ;AACd,MAAIC,IAAS;AACb,WAASC,IAAI,GAAGA,IAAIH,GAAQG;AAChB,IAAAD,KAAAD,EAAM,OAAO,KAAK,MAAM,KAAK,OAAO,IAAIA,EAAM,MAAM,CAAC;AAE1D,SAAAC;AACT;AACgB,SAAAE,EAAeC,GAAaP,GAAgC;AAClE,UAAA,IAAI,kBAAkBO,GAAKP,CAAG,GACtCD,EAAe,QAAQ,CAAYS,MAAA;AAEjC,UAAMC,IAAQD,EAAS,OAAOR,CAAG,KAAK,IAEhCU,IAAQ,IAAI,OAAOF,EAAS,OAAO,GAAG;AACtC,IAAAD,IAAAA,EAAI,QAAQG,GAAOD,CAAK;AAAA,EAAA,CAC/B;AAGD,QAAME,IAAY;AAClB,SAAAJ,IAAMA,EAAI,QAAQI,GAAW,CAACC,GAAOC,MAAO;AACpC,UAAAX,IAAS,SAASW,GAAI,EAAE;AAC9B,WAAOZ,EAAqBC,CAAM;AAAA,EAAA,CACnC,GAEMK;AACT;ACxJO,MAAeO,EAA0D;AAAA,EAE9E,OAAa;AACX,SAAK,OAAO;AAAA,EAAA;AAAA,EAUd,UAAU;AACR,SAAK,UAAU;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAsBV,WAAWC,GAAgD;AACzD,WAAA,QAAQ,QAAQ,EAAK;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASpB,iBAAiBC,GAAqBD,GAA2B;AAClE,WAAAT,EAAeU,GAAaD,CAAM;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQjC,iBAAiBE,GAAqB;AAC1C,QAAA;AAEF,aADe,IAAI,IAAIA,CAAG,EACZ;AAAA,YACA;AAER,YAAAC,IAAUD,EAAI,MAAM,yBAAyB;AAC5C,aAAAC,IAAUA,EAAQ,CAAC,IAAI;AAAA,IAAA;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUK,aAAarB,GAA0B;AACrC,WAAA,QAAQ,QAAQ,MAAS;AAAA,EAAA;AAAA,EAGxB,WAAWsB,GAAsB;AACnC,UAAAC,IAAM,iBAAiBD,CAAS;AAC/B,WAAA,OAAO,gBAAgB,QAAQC,CAAG;AAAA,EAAA;AAAA,EAGjC,WAAWD,GAAmBtB,GAAiB;AACjD,UAAAuB,IAAM,iBAAiBD,CAAS;AAC/B,WAAA,gBAAgB,QAAQC,GAAKvB,CAAM;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EAM5C,YAAY;AAAA,EAAA;AAGd;"}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
|
+
import { AsyncComponentLoader, AsyncComponentOptions } from '@vue';
|
|
1
2
|
export interface StorageUIFormElement {
|
|
2
|
-
type: 'input' | 'input-format' | 'radio-group' | 'switch' | 'input-button';
|
|
3
|
+
type: 'input' | 'input-format' | 'radio-group' | 'switch' | 'input-button' | 'select' | 'custom';
|
|
4
|
+
customComponent?: AsyncComponentLoader | AsyncComponentOptions;
|
|
3
5
|
formItem: {
|
|
4
6
|
rules?: Record<string, any>;
|
|
5
7
|
field: string;
|
|
@@ -10,6 +12,10 @@ export interface StorageUIFormElement {
|
|
|
10
12
|
* 元素属性值
|
|
11
13
|
*/
|
|
12
14
|
elementProperty: Record<string, any>;
|
|
15
|
+
/**
|
|
16
|
+
* 元素事件
|
|
17
|
+
*/
|
|
18
|
+
elementEvent?: Record<string, any>;
|
|
13
19
|
}
|
|
14
20
|
export interface StorageUIConfig {
|
|
15
21
|
/**
|