@xiaou66/picture-plugin 0.0.45 → 0.0.46

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.
@@ -1,33 +1,5 @@
1
- import { AsyncComponentLoader, AsyncComponentOptions } from 'vue';
1
+ import { AsyncComponentLoader } from 'vue';
2
2
  import { PlugInfo } from '../core';
3
- export interface StorageUIFormElement {
4
- type: 'input' | 'input-format' | 'radio-group' | 'switch' | 'input-button' | 'select' | 'custom';
5
- customComponent?: AsyncComponentLoader | AsyncComponentOptions;
6
- formItem: {
7
- rules?: Record<string, any>;
8
- field: string;
9
- label: string;
10
- [key: string]: any;
11
- };
12
- /**
13
- * 元素属性值
14
- */
15
- elementProperty: Record<string, any>;
16
- /**
17
- * 元素事件
18
- */
19
- elementEvent?: Record<string, any>;
20
- }
21
- export interface StorageUIConfig {
22
- /**
23
- * 提示
24
- */
25
- tips: string;
26
- /**
27
- * 表单
28
- */
29
- forms: StorageUIFormElement[];
30
- }
31
3
  export interface FlowNodePlugInfo extends PlugInfo {
32
4
  /**
33
5
  * 插件分组
package/dist/index.cjs.js CHANGED
@@ -1,2 +1,2 @@
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;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});function i(e){const t=e;return t.pluginInfo.pluginType="storage",t}const u=[{label:"年",value:"{YY}",demo:()=>new Date().getFullYear().toString(),format:e=>new Date().getFullYear().toString()},{label:"年",value:"{Y}",demo:()=>new Date().getFullYear().toString().substring(2),format:e=>new Date().getFullYear().toString().substring(2)},{label:"月",value:"{M}",demo:()=>(new Date().getMonth()+1).toString().padStart(2,"0"),format:e=>(new Date().getMonth()+1).toString().padStart(2,"0")},{label:"日",value:"{D}",demo:()=>new Date().getDate().toString().padStart(2,"0"),format:e=>new Date().getDate().toString().padStart(2,"0")},{label:"时",value:"{h}",demo:()=>new Date().getHours().toString().padStart(2,"0"),format:e=>new Date().getHours().toString().padStart(2,"0")},{label:"分",value:"{m}",demo:()=>new Date().getMinutes().toString().padStart(2,"0"),format:e=>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:e=>new Date().getMilliseconds().toString().padStart(3,"0")},{label:"时间戳",value:"{timestamp}",width:300,demo:()=>Date.now(),format:e=>Date.now().toString()},{label:"文件名称",value:"{filename}",width:200,demo:()=>"文本",format:e=>e.fileName},{label:"后缀",value:"{suffix}",width:200,demo:()=>"txt",format:e=>e.suffix},{label:"全文件名",value:"{allFilename}",width:300,demo:()=>"文本.txt",format:e=>e.allFileName},{label:"场景名称",value:"{sceneName}",width:300,demo:()=>"测试场景",format:e=>e.sceneName||""},{label:"随机字符串",value:"{rand(5)}",width:300,demo:()=>l(5),format:e=>l(5)}];function l(e){const t="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";let r="";for(let n=0;n<e;n++)r+=t.charAt(Math.floor(Math.random()*t.length));return r}function g(e,t){console.log("filePathFormat",e,t),u.forEach(n=>{const a=n.format(t)||"",o=new RegExp(n.value,"g");e=e.replace(o,a)});const r=/\{rand\((\d+)\)\}/g;return e=e.replace(r,(n,a)=>{const o=parseInt(a,10);return l(o)}),e}class s{init(){this.doInit()}destroy(){this.doDestroy()}deleteFile(t){return Promise.resolve(!1)}formatUploadPath(t,r){return g(t,r)}extractImagePath(t){try{return new URL(t).pathname}catch{const n=t.match(/https?:\/\/[^\/]+(\/.*)/);return n?n[1]:""}}verifyConfig(t){return Promise.resolve(void 0)}readConfig(t){const r=`storageSource/${t}`;return utools.dbCryptoStorage.getItem(r)}saveConfig(t,r){const n=`storageSource/${t}`;utools.dbCryptoStorage.setItem(n,r)}uninstall(){}}function d(e){const t=e;return t.pluginInfo.pluginType="flowNode",t}function m(e){return e}exports.StoragePlugIn=s;exports.createFlowNodePlugInActions=m;exports.createFlowNodePlugInConfig=d;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":["import { AsyncComponentLoader, AsyncComponentOptions } from 'vue'\nimport { PlugInfo } from '../core'\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 StoragePlugInfo extends PlugInfo {\n /**\n * 插件分组\n */\n pluginGroup: 'cloudVendor' | 'self' | 'other';\n}\nexport interface StoragePlugInConfig {\n\n /**\n * 无需配置可以直接使用\n */\n noConfig?: boolean;\n\n pluginInfo: StoragePlugInfo;\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<StoragePlugInfo, '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\nexport interface UploadFileOptions {\n onProgress?: (progress: number) => 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 * @param options 上传可选参数\n */\n abstract uploadFile(params: IUploadFileParams, options?: UploadFileOptions): 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","../src/flowNode/FlowNodePlugIn.ts"],"sourcesContent":["import { AsyncComponentLoader, AsyncComponentOptions } from 'vue'\nimport { PlugInfo } from '../core'\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 StoragePlugInfo extends PlugInfo {\n /**\n * 插件分组\n */\n pluginGroup: 'cloudVendor' | 'self' | 'other';\n}\nexport interface StoragePlugInConfig {\n\n /**\n * 无需配置可以直接使用\n */\n noConfig?: boolean;\n\n pluginInfo: StoragePlugInfo;\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<StoragePlugInfo, '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\nexport interface UploadFileOptions {\n onProgress?: (progress: number) => 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 * @param options 上传可选参数\n */\n abstract uploadFile(params: IUploadFileParams, options?: UploadFileOptions): 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","import { AsyncComponentLoader, AsyncComponentOptions } from 'vue'\nimport { PlugInfo } from '../core'\n\ninterface 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\ninterface StorageUIConfig {\n /**\n * 提示\n */\n tips: string,\n\n /**\n * 表单\n */\n forms: StorageUIFormElement[];\n}\n\n\nexport interface FlowNodePlugInfo extends PlugInfo {\n /**\n * 插件分组\n */\n pluginGroup: 'image' | 'music' | 'video' | 'other' | 'trigger' | 'common' | 'finish';\n}\n\n\nexport interface FlowNodePlugIn {\n\n /**\n * 无需配置可以直接使用\n */\n noConfig?: boolean;\n\n pluginInfo: FlowNodePlugInfo;\n\n // /**\n // * 配置 ui\n // */\n // uiConfig?: StorageUIConfig;\n\n /**\n * 自定义配置 UI 如果配置这个 {@link uiConfig} 配置将无效\n */\n uiConfigComponent?: AsyncComponentLoader;\n}\n\ninterface FileUpdateInfoItem {\n id: string;\n\n /**\n * 文件路径\n */\n filePath: string;\n\n /**\n * 放 base64 的\n */\n content?: string;\n\n\n /**\n * 文件名称\n */\n fileName: string;\n\n /**\n * 文件后缀\n */\n fileSuffix: string;\n\n /**\n * 是否临时文件, 即 base64 文件\n */\n tempFile?: boolean;\n\n /**\n * 文件大小\n */\n fileSize: number;\n\n /**\n * 场景名称\n */\n sceneName?: string;\n\n /**\n * 上传方式\n */\n uploadWay: string;\n\n /**\n * 上传状态\n */\n uploadStatus: 'waiting' | 'uploading' | 'failed';\n\n progress?: number;\n}\n\ninterface SceneInfoItem {\n id: string;\n /**\n * 场景名称\n */\n sceneName: string;\n /**\n * 是否启用\n */\n enable: boolean;\n}\n\ninterface FileUploadInfo {\n\n /**\n * 存储源 id\n */\n storageId: string;\n\n /**\n * URL\n */\n url: string;\n\n /**\n * 额外数据\n */\n extra: any;\n}\n\nexport interface FileLibraryInfo {\n /**\n * 文件名称\n */\n fileName: string;\n\n /**\n * 文件后缀\n */\n fileSuffix: string;\n\n /**\n * 文件大小\n */\n fileSize: number;\n}\ninterface FileLibraryItem {\n /**\n * id\n */\n id: string;\n\n /**\n * 分组 id\n */\n fileBoxId: string;\n\n /**\n * 文件保存实际的 docId\n */\n fileFileBoxDocId?: string;\n\n /**\n * 场景 id\n */\n sceneId: string;\n\n /**\n * 上传文件信息\n */\n fileUploadInfoList: FileUploadInfo[];\n\n /**\n * 文件信息\n */\n fileInfo: FileLibraryInfo;\n\n /**\n * 标签分组 id\n */\n tags?: string[];\n\n /**\n * 创建时间\n */\n createTime: number;\n}\n\n\n\ninterface IFlowNode<T=any> {\n id: string;\n nodeCode: string;\n nodeData: T | Record<string, any>;\n}\n\ninterface IFlowItem {\n id: string;\n nodeList: IFlowNode[];\n createAt: number;\n updateAt: number;\n}\n\nexport interface IFlowContext {\n uploadFile: FileUpdateInfoItem,\n fileLibrary: FileLibraryItem,\n sceneInfo: SceneInfoItem,\n context?: Record<string, any>,\n}\n\nexport interface IFlowNodeActions<T> {\n execute?: (flow: IFlowItem, flowData: IFlowNode<T>, data: IFlowContext) => Promise<void>;\n onSaveData?: (flow: IFlowItem, flowData: IFlowNode<T>) => void;\n onDestroy?: (flow: IFlowItem, flowData: IFlowNode<T>) => void;\n adjustData?: (flow: IFlowItem, flowData: IFlowNode<T>) => Promise<boolean>;\n}\n\n\n/**\n * 流程节点插件配置\n * @param config\n */\nexport function createFlowNodePlugInConfig(config: Omit<FlowNodePlugIn, 'pluginInfo'> & { pluginInfo: Omit<FlowNodePlugInfo, 'pluginType'> }): FlowNodePlugIn {\n const newConfig = config as FlowNodePlugIn\n newConfig.pluginInfo.pluginType = 'flowNode';\n return newConfig;\n}\n\n/**\n * 创建流程节点插件\n * @param actions\n */\nexport function createFlowNodePlugInActions<T>(actions: IFlowNodeActions<T>) {\n return actions;\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","createFlowNodePlugInConfig","createFlowNodePlugInActions","actions"],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -1,2 +1,4 @@
1
1
  export * from './storage';
2
2
  export * from './utils';
3
+ export * from './core';
4
+ export * from './flowNode';
package/dist/index.es.js CHANGED
@@ -1,4 +1,4 @@
1
- function i(t) {
1
+ function g(t) {
2
2
  const e = t;
3
3
  return e.pluginInfo.pluginType = "storage", e;
4
4
  }
@@ -97,18 +97,18 @@ const u = [
97
97
  function l(t) {
98
98
  const e = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
99
99
  let r = "";
100
- for (let a = 0; a < t; a++)
100
+ for (let n = 0; n < t; n++)
101
101
  r += e.charAt(Math.floor(Math.random() * e.length));
102
102
  return r;
103
103
  }
104
- function g(t, e) {
105
- console.log("filePathFormat", t, e), u.forEach((a) => {
106
- const n = a.format(e) || "", o = new RegExp(a.value, "g");
107
- t = t.replace(o, n);
104
+ function i(t, e) {
105
+ console.log("filePathFormat", t, e), u.forEach((n) => {
106
+ const a = n.format(e) || "", o = new RegExp(n.value, "g");
107
+ t = t.replace(o, a);
108
108
  });
109
109
  const r = /\{rand\((\d+)\)\}/g;
110
- return t = t.replace(r, (a, n) => {
111
- const o = parseInt(n, 10);
110
+ return t = t.replace(r, (n, a) => {
111
+ const o = parseInt(a, 10);
112
112
  return l(o);
113
113
  }), t;
114
114
  }
@@ -134,7 +134,7 @@ class s {
134
134
  * @protected
135
135
  */
136
136
  formatUploadPath(e, r) {
137
- return g(e, r);
137
+ return i(e, r);
138
138
  }
139
139
  /**
140
140
  * 从 URL 中提取路径
@@ -145,8 +145,8 @@ class s {
145
145
  try {
146
146
  return new URL(e).pathname;
147
147
  } catch {
148
- const a = e.match(/https?:\/\/[^\/]+(\/.*)/);
149
- return a ? a[1] : "";
148
+ const n = e.match(/https?:\/\/[^\/]+(\/.*)/);
149
+ return n ? n[1] : "";
150
150
  }
151
151
  }
152
152
  /**
@@ -163,8 +163,8 @@ class s {
163
163
  return utools.dbCryptoStorage.getItem(r);
164
164
  }
165
165
  saveConfig(e, r) {
166
- const a = `storageSource/${e}`;
167
- utools.dbCryptoStorage.setItem(a, r);
166
+ const n = `storageSource/${e}`;
167
+ utools.dbCryptoStorage.setItem(n, r);
168
168
  }
169
169
  /**
170
170
  * 插件被卸载
@@ -172,10 +172,19 @@ class s {
172
172
  uninstall() {
173
173
  }
174
174
  }
175
+ function d(t) {
176
+ const e = t;
177
+ return e.pluginInfo.pluginType = "flowNode", e;
178
+ }
179
+ function m(t) {
180
+ return t;
181
+ }
175
182
  export {
176
183
  s as StoragePlugIn,
177
- i as createStoragePlugInConfig,
178
- g as filePathFormat,
184
+ m as createFlowNodePlugInActions,
185
+ d as createFlowNodePlugInConfig,
186
+ g as createStoragePlugInConfig,
187
+ i as filePathFormat,
179
188
  u as stringVariable
180
189
  };
181
190
  //# 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":["import { AsyncComponentLoader, AsyncComponentOptions } from 'vue'\nimport { PlugInfo } from '../core'\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 StoragePlugInfo extends PlugInfo {\n /**\n * 插件分组\n */\n pluginGroup: 'cloudVendor' | 'self' | 'other';\n}\nexport interface StoragePlugInConfig {\n\n /**\n * 无需配置可以直接使用\n */\n noConfig?: boolean;\n\n pluginInfo: StoragePlugInfo;\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<StoragePlugInfo, '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\nexport interface UploadFileOptions {\n onProgress?: (progress: number) => 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 * @param options 上传可选参数\n */\n abstract uploadFile(params: IUploadFileParams, options?: UploadFileOptions): 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","../src/flowNode/FlowNodePlugIn.ts"],"sourcesContent":["import { AsyncComponentLoader, AsyncComponentOptions } from 'vue'\nimport { PlugInfo } from '../core'\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 StoragePlugInfo extends PlugInfo {\n /**\n * 插件分组\n */\n pluginGroup: 'cloudVendor' | 'self' | 'other';\n}\nexport interface StoragePlugInConfig {\n\n /**\n * 无需配置可以直接使用\n */\n noConfig?: boolean;\n\n pluginInfo: StoragePlugInfo;\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<StoragePlugInfo, '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\nexport interface UploadFileOptions {\n onProgress?: (progress: number) => 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 * @param options 上传可选参数\n */\n abstract uploadFile(params: IUploadFileParams, options?: UploadFileOptions): 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","import { AsyncComponentLoader, AsyncComponentOptions } from 'vue'\nimport { PlugInfo } from '../core'\n\ninterface 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\ninterface StorageUIConfig {\n /**\n * 提示\n */\n tips: string,\n\n /**\n * 表单\n */\n forms: StorageUIFormElement[];\n}\n\n\nexport interface FlowNodePlugInfo extends PlugInfo {\n /**\n * 插件分组\n */\n pluginGroup: 'image' | 'music' | 'video' | 'other' | 'trigger' | 'common' | 'finish';\n}\n\n\nexport interface FlowNodePlugIn {\n\n /**\n * 无需配置可以直接使用\n */\n noConfig?: boolean;\n\n pluginInfo: FlowNodePlugInfo;\n\n // /**\n // * 配置 ui\n // */\n // uiConfig?: StorageUIConfig;\n\n /**\n * 自定义配置 UI 如果配置这个 {@link uiConfig} 配置将无效\n */\n uiConfigComponent?: AsyncComponentLoader;\n}\n\ninterface FileUpdateInfoItem {\n id: string;\n\n /**\n * 文件路径\n */\n filePath: string;\n\n /**\n * 放 base64 的\n */\n content?: string;\n\n\n /**\n * 文件名称\n */\n fileName: string;\n\n /**\n * 文件后缀\n */\n fileSuffix: string;\n\n /**\n * 是否临时文件, 即 base64 文件\n */\n tempFile?: boolean;\n\n /**\n * 文件大小\n */\n fileSize: number;\n\n /**\n * 场景名称\n */\n sceneName?: string;\n\n /**\n * 上传方式\n */\n uploadWay: string;\n\n /**\n * 上传状态\n */\n uploadStatus: 'waiting' | 'uploading' | 'failed';\n\n progress?: number;\n}\n\ninterface SceneInfoItem {\n id: string;\n /**\n * 场景名称\n */\n sceneName: string;\n /**\n * 是否启用\n */\n enable: boolean;\n}\n\ninterface FileUploadInfo {\n\n /**\n * 存储源 id\n */\n storageId: string;\n\n /**\n * URL\n */\n url: string;\n\n /**\n * 额外数据\n */\n extra: any;\n}\n\nexport interface FileLibraryInfo {\n /**\n * 文件名称\n */\n fileName: string;\n\n /**\n * 文件后缀\n */\n fileSuffix: string;\n\n /**\n * 文件大小\n */\n fileSize: number;\n}\ninterface FileLibraryItem {\n /**\n * id\n */\n id: string;\n\n /**\n * 分组 id\n */\n fileBoxId: string;\n\n /**\n * 文件保存实际的 docId\n */\n fileFileBoxDocId?: string;\n\n /**\n * 场景 id\n */\n sceneId: string;\n\n /**\n * 上传文件信息\n */\n fileUploadInfoList: FileUploadInfo[];\n\n /**\n * 文件信息\n */\n fileInfo: FileLibraryInfo;\n\n /**\n * 标签分组 id\n */\n tags?: string[];\n\n /**\n * 创建时间\n */\n createTime: number;\n}\n\n\n\ninterface IFlowNode<T=any> {\n id: string;\n nodeCode: string;\n nodeData: T | Record<string, any>;\n}\n\ninterface IFlowItem {\n id: string;\n nodeList: IFlowNode[];\n createAt: number;\n updateAt: number;\n}\n\nexport interface IFlowContext {\n uploadFile: FileUpdateInfoItem,\n fileLibrary: FileLibraryItem,\n sceneInfo: SceneInfoItem,\n context?: Record<string, any>,\n}\n\nexport interface IFlowNodeActions<T> {\n execute?: (flow: IFlowItem, flowData: IFlowNode<T>, data: IFlowContext) => Promise<void>;\n onSaveData?: (flow: IFlowItem, flowData: IFlowNode<T>) => void;\n onDestroy?: (flow: IFlowItem, flowData: IFlowNode<T>) => void;\n adjustData?: (flow: IFlowItem, flowData: IFlowNode<T>) => Promise<boolean>;\n}\n\n\n/**\n * 流程节点插件配置\n * @param config\n */\nexport function createFlowNodePlugInConfig(config: Omit<FlowNodePlugIn, 'pluginInfo'> & { pluginInfo: Omit<FlowNodePlugInfo, 'pluginType'> }): FlowNodePlugIn {\n const newConfig = config as FlowNodePlugIn\n newConfig.pluginInfo.pluginType = 'flowNode';\n return newConfig;\n}\n\n/**\n * 创建流程节点插件\n * @param actions\n */\nexport function createFlowNodePlugInActions<T>(actions: IFlowNodeActions<T>) {\n return actions;\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","createFlowNodePlugInConfig","createFlowNodePlugInActions","actions"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xiaou66/picture-plugin",
3
- "version": "0.0.45",
3
+ "version": "0.0.46",
4
4
  "description": "Picture bed plugin system",
5
5
  "main": "./dist/index.cjs.js",
6
6
  "module": "./dist/index.es.js",