@xiaou66/picture-plugin 0.0.35 → 0.0.36

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 CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});function g(t){const e=t;return e.pluginInfo.pluginType="storage",e}const u=[{label:"年",value:"{YY}",demo:()=>new Date().getFullYear().toString(),format:t=>new Date().getFullYear().toString()},{label:"年",value:"{Y}",demo:()=>new Date().getFullYear().toString().substring(2),format:t=>new Date().getFullYear().toString().substring(2)},{label:"月",value:"{M}",demo:()=>(new Date().getMonth()+1).toString().padStart(2,"0"),format:t=>(new Date().getMonth()+1).toString().padStart(2,"0")},{label:"日",value:"{D}",demo:()=>new Date().getDate().toString().padStart(2,"0"),format:t=>new Date().getDate().toString().padStart(2,"0")},{label:"时",value:"{h}",demo:()=>new Date().getHours().toString().padStart(2,"0"),format:t=>new Date().getHours().toString().padStart(2,"0")},{label:"分",value:"{m}",demo:()=>new Date().getMinutes().toString().padStart(2,"0"),format:t=>new Date().getMinutes().toString().padStart(2,"0")},{label:"秒",value:"{s}",demo:()=>new Date().getSeconds().toString().padStart(2,"0"),format:()=>new Date().getSeconds().toString().padStart(2,"0")},{label:"毫秒",value:"{ss}",demo:()=>new Date().getMilliseconds().toString().padStart(3,"0"),format:t=>new Date().getMilliseconds().toString().padStart(3,"0")},{label:"时间戳",value:"{timestamp}",width:300,demo:()=>Date.now(),format:t=>Date.now().toString()},{label:"文件名称",value:"{filename}",width:200,demo:()=>"文本",format:t=>t.fileName},{label:"后缀",value:"{suffix}",width:200,demo:()=>"txt",format:t=>t.suffix},{label:"全文件名",value:"{allFilename}",width:300,demo:()=>"文本.txt",format:t=>t.allFileName},{label:"场景名称",value:"{sceneName}",width:300,demo:()=>"测试场景",format:t=>t.sceneName||""},{label:"随机字符串",value:"{rand(5)}",width:300,demo:()=>l(5),format:t=>l(5)}];function l(t){const e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";let r="";for(let a=0;a<t;a++)r+=e.charAt(Math.floor(Math.random()*e.length));return r}function i(t,e){console.log("filePathFormat",t,e),u.forEach(a=>{const n=a.format(e)||"",o=new RegExp(a.value,"g");t=t.replace(o,n)});const r=/\{rand\((\d+)\)\}/g;return t=t.replace(r,(a,n)=>{const o=parseInt(n,10);return l(o)}),t}class m{init(){this.doInit()}destroy(){this.doDestroy()}deleteFile(e){return Promise.resolve(!1)}formatUploadPath(e,r){return i(e,r)}extractImagePath(e){try{return new URL(e).pathname}catch{const a=e.match(/https?:\/\/[^\/]+(\/.*)/);return a?a[1]:""}}verifyConfig(e){return Promise.resolve(void 0)}readConfig(e){const r=`storageSource/${e}`;return utools.dbCryptoStorage.getItem(r)}uninstall(){}}exports.StoragePlugIn=m;exports.createStoragePlugInConfig=g;exports.filePathFormat=i;exports.stringVariable=u;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});function i(t){const e=t;return e.pluginInfo.pluginType="storage",e}const u=[{label:"年",value:"{YY}",demo:()=>new Date().getFullYear().toString(),format:t=>new Date().getFullYear().toString()},{label:"年",value:"{Y}",demo:()=>new Date().getFullYear().toString().substring(2),format:t=>new Date().getFullYear().toString().substring(2)},{label:"月",value:"{M}",demo:()=>(new Date().getMonth()+1).toString().padStart(2,"0"),format:t=>(new Date().getMonth()+1).toString().padStart(2,"0")},{label:"日",value:"{D}",demo:()=>new Date().getDate().toString().padStart(2,"0"),format:t=>new Date().getDate().toString().padStart(2,"0")},{label:"时",value:"{h}",demo:()=>new Date().getHours().toString().padStart(2,"0"),format:t=>new Date().getHours().toString().padStart(2,"0")},{label:"分",value:"{m}",demo:()=>new Date().getMinutes().toString().padStart(2,"0"),format:t=>new Date().getMinutes().toString().padStart(2,"0")},{label:"秒",value:"{s}",demo:()=>new Date().getSeconds().toString().padStart(2,"0"),format:()=>new Date().getSeconds().toString().padStart(2,"0")},{label:"毫秒",value:"{ss}",demo:()=>new Date().getMilliseconds().toString().padStart(3,"0"),format:t=>new Date().getMilliseconds().toString().padStart(3,"0")},{label:"时间戳",value:"{timestamp}",width:300,demo:()=>Date.now(),format:t=>Date.now().toString()},{label:"文件名称",value:"{filename}",width:200,demo:()=>"文本",format:t=>t.fileName},{label:"后缀",value:"{suffix}",width:200,demo:()=>"txt",format:t=>t.suffix},{label:"全文件名",value:"{allFilename}",width:300,demo:()=>"文本.txt",format:t=>t.allFileName},{label:"场景名称",value:"{sceneName}",width:300,demo:()=>"测试场景",format:t=>t.sceneName||""},{label:"随机字符串",value:"{rand(5)}",width:300,demo:()=>l(5),format:t=>l(5)}];function l(t){const e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";let r="";for(let a=0;a<t;a++)r+=e.charAt(Math.floor(Math.random()*e.length));return r}function g(t,e){console.log("filePathFormat",t,e),u.forEach(a=>{const n=a.format(e)||"",o=new RegExp(a.value,"g");t=t.replace(o,n)});const r=/\{rand\((\d+)\)\}/g;return t=t.replace(r,(a,n)=>{const o=parseInt(n,10);return l(o)}),t}class s{init(){this.doInit()}destroy(){this.doDestroy()}deleteFile(e){return Promise.resolve(!1)}formatUploadPath(e,r){return g(e,r)}extractImagePath(e){try{return new URL(e).pathname}catch{const a=e.match(/https?:\/\/[^\/]+(\/.*)/);return a?a[1]:""}}verifyConfig(e){return Promise.resolve(void 0)}readConfig(e){const r=`storageSource/${e}`;return utools.dbCryptoStorage.getItem(r)}saveConfig(e,r){const a=`storageSource/${e}`;utools.dbCryptoStorage.setItem(a,r)}uninstall(){}}exports.StoragePlugIn=s;exports.createStoragePlugInConfig=i;exports.filePathFormat=g;exports.stringVariable=u;
2
2
  //# sourceMappingURL=index.cjs.js.map
@@ -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 /**\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":["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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"}
package/dist/index.es.js CHANGED
@@ -1,4 +1,4 @@
1
- function g(t) {
1
+ function i(t) {
2
2
  const e = t;
3
3
  return e.pluginInfo.pluginType = "storage", e;
4
4
  }
@@ -101,7 +101,7 @@ function l(t) {
101
101
  r += e.charAt(Math.floor(Math.random() * e.length));
102
102
  return r;
103
103
  }
104
- function i(t, e) {
104
+ function g(t, e) {
105
105
  console.log("filePathFormat", t, e), u.forEach((a) => {
106
106
  const n = a.format(e) || "", o = new RegExp(a.value, "g");
107
107
  t = t.replace(o, n);
@@ -112,7 +112,7 @@ function i(t, e) {
112
112
  return l(o);
113
113
  }), t;
114
114
  }
115
- class m {
115
+ class s {
116
116
  init() {
117
117
  this.doInit();
118
118
  }
@@ -134,7 +134,7 @@ class m {
134
134
  * @protected
135
135
  */
136
136
  formatUploadPath(e, r) {
137
- return i(e, r);
137
+ return g(e, r);
138
138
  }
139
139
  /**
140
140
  * 从 URL 中提取路径
@@ -162,6 +162,10 @@ class m {
162
162
  const r = `storageSource/${e}`;
163
163
  return utools.dbCryptoStorage.getItem(r);
164
164
  }
165
+ saveConfig(e, r) {
166
+ const a = `storageSource/${e}`;
167
+ utools.dbCryptoStorage.setItem(a, r);
168
+ }
165
169
  /**
166
170
  * 插件被卸载
167
171
  */
@@ -169,9 +173,9 @@ class m {
169
173
  }
170
174
  }
171
175
  export {
172
- m as StoragePlugIn,
173
- g as createStoragePlugInConfig,
174
- i as filePathFormat,
176
+ s as StoragePlugIn,
177
+ i as createStoragePlugInConfig,
178
+ g as filePathFormat,
175
179
  u as stringVariable
176
180
  };
177
181
  //# sourceMappingURL=index.es.js.map
@@ -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 /**\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":"AAyFO,SAASA,EAA0BC,GAAqH;AAC7J,QAAMC,IAAYD;AAClB,SAAAC,EAAU,WAAW,aAAa,WAC3BA;AACT;AC1FO,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;AAAA;AAAA;AAAA,EAM3C,YAAY;AAAA,EAAA;AAGd;"}
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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"}
@@ -62,6 +62,7 @@ export declare abstract class StoragePlugIn<C = any, E = any> implements IStorag
62
62
  */
63
63
  verifyConfig(config: C): Promise<void>;
64
64
  protected readConfig(storageId: string): C;
65
+ protected saveConfig(storageId: string, config: C): void;
65
66
  /**
66
67
  * 插件被卸载
67
68
  */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xiaou66/picture-plugin",
3
- "version": "0.0.35",
3
+ "version": "0.0.36",
4
4
  "description": "Picture bed plugin system",
5
5
  "main": "./dist/index.cjs.js",
6
6
  "module": "./dist/index.es.js",