@xiaou66/picture-plugin 0.0.45 → 0.0.47
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/core/PluginInfo.d.ts +3 -0
- package/dist/core/index.d.ts +1 -1
- package/dist/flowNode/FlowNodePlugin.d.ts +9 -0
- package/dist/flowNode/index.d.ts +1 -1
- package/dist/index.cjs.js +2 -2
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.es.js +153 -176
- package/dist/index.es.js.map +1 -1
- package/dist/storage/{StoragePlugIn.d.ts → StoragePlugin.d.ts} +4 -7
- package/dist/storage/StoragePluginConfig.d.ts +9 -0
- package/dist/storage/StoragePluginType.d.ts +1 -0
- package/dist/storage/index.d.ts +3 -3
- package/package.json +10 -3
- package/dist/core/PlugInInfo.d.ts +0 -33
- package/dist/flowNode/FlowNodePlugIn.d.ts +0 -196
- package/dist/storage/StoragePlugInConfig.d.ts +0 -57
- package/dist/storage/StoragePlugInType.d.ts +0 -62
package/dist/core/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from './
|
|
1
|
+
export * from './PluginInfo';
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { FlowNodePlugin, FlowNodePluginInfo } from '@xiaou66/picture-types';
|
|
2
|
+
export type { FlowNodePluginInfo, FlowNodePlugin, IFlowContext, IFlowNodeActions, FileUpdateInfoItem, SceneInfoItem, FileUploadInfo, FileLibraryInfo, FileLibraryItem, IFlowNode, IFlowItem, } from '@xiaou66/picture-types';
|
|
3
|
+
/**
|
|
4
|
+
* 流程节点插件配置
|
|
5
|
+
* @param config
|
|
6
|
+
*/
|
|
7
|
+
export declare function createFlowNodePluginConfig(config: Omit<FlowNodePlugin, 'pluginInfo'> & {
|
|
8
|
+
pluginInfo: Omit<FlowNodePluginInfo, 'pluginType'>;
|
|
9
|
+
}): FlowNodePlugin;
|
package/dist/flowNode/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from './
|
|
1
|
+
export * from './FlowNodePlugin';
|
package/dist/index.cjs.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
//# sourceMappingURL=index.cjs.js.map
|
|
1
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});function e(e){let t=e;return t.pluginInfo.pluginType=`storage`,t}const t=[{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:()=>n(5),format:e=>n(5)}];function n(e){let t=``;for(let n=0;n<e;n++)t+=`ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789`.charAt(Math.floor(Math.random()*62));return t}function r(e,r){return console.log(`filePathFormat`,e,r),t.forEach(t=>{let n=t.format(r)||``,i=new RegExp(t.value,`g`);e=e.replace(i,n)}),e=e.replace(/\{rand\((\d+)\)\}/g,(e,t)=>n(parseInt(t,10))),e}var i=class{init(){this.doInit()}destroy(){this.doDestroy()}deleteFile(e){return Promise.resolve(!1)}formatUploadPath(e,t){return r(e,t)}extractImagePath(e){try{return new URL(e).pathname}catch{let t=e.match(/https?:\/\/[^\/]+(\/.*)/);return t?t[1]:``}}verifyConfig(e){return Promise.resolve(void 0)}readConfig(e){let t=`storageSource/${e}`;return utools.dbCryptoStorage.getItem(t)}saveConfig(e,t){let n=`storageSource/${e}`;utools.dbCryptoStorage.setItem(n,t)}uninstall(){}};const a={storage:{name:`存储`,icon:`i-u-cloud-storage`},flowNode:{name:`流程`,icon:`i-u-flow`}};function o(e){let t=e;return t.pluginInfo.pluginType=`flowNode`,t}exports.StoragePlugin=i,exports.createFlowNodePluginConfig=o,exports.createStoragePluginConfig=e,exports.filePathFormat=r,exports.pluginTypeDict=a,exports.stringVariable=t;
|
|
2
|
+
//# sourceMappingURL=index.cjs.js.map
|
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":["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","names":["pluginTypeDict: Record<PluginType, Record<string, string>>"],"sources":["../src/storage/StoragePluginConfig.ts","../src/utils/StrTemplateUtils.ts","../src/storage/StoragePlugin.ts","../src/core/PluginInfo.ts","../src/flowNode/FlowNodePlugin.ts"],"sourcesContent":["// 从 types 包导入并重新导出\nexport type {\n StorageUIFormElement,\n StorageUIConfig,\n StoragePluginInfo,\n StoragePluginConfig,\n} from '@xiaou66/picture-types'\n\nimport type { StoragePluginConfig, StoragePluginInfo } from '@xiaou66/picture-types'\n\n/**\n * 存储插件配置\n * @param config\n */\nexport function createStoragePluginConfig(config: Omit<StoragePluginConfig, 'pluginInfo'> & { pluginInfo: Omit<StoragePluginInfo, '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 type { IDeleteFileParams, IUploadFileParams, IUploadFileResult, UploadFileOptions } from '@xiaou66/picture-types'\nimport { filePathFormat } from '../utils'\n\n// 重新导出 UploadFileOptions\nexport type { UploadFileOptions } from '@xiaou66/picture-types'\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 * @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","// 从 types 包导入并重新导出\nexport type { PluginType, PluginInfo, PluginConfig } from '@xiaou66/picture-types'\nimport type { PluginType } from '@xiaou66/picture-types'\n\nexport const pluginTypeDict: Record<PluginType, Record<string, string>> = {\n 'storage': {\n name: '存储',\n icon: 'i-u-cloud-storage',\n },\n 'flowNode': {\n name: '流程',\n icon: 'i-u-flow'\n },\n}\n","// 从 types 包导入并重新导出\nexport type {\n FlowNodePluginInfo,\n FlowNodePlugin,\n IFlowContext,\n IFlowNodeActions,\n // 以下类型在 types 包的其他文件中定义,这里也重新导出以保持兼容\n FileUpdateInfoItem,\n SceneInfoItem,\n FileUploadInfo,\n FileLibraryInfo,\n FileLibraryItem,\n IFlowNode,\n IFlowItem,\n} from '@xiaou66/picture-types'\n\nimport type { FlowNodePlugin, FlowNodePluginInfo } from '@xiaou66/picture-types'\n\n/**\n * 流程节点插件配置\n * @param config\n */\nexport function createFlowNodePluginConfig(config: Omit<FlowNodePlugin, 'pluginInfo'> & { pluginInfo: Omit<FlowNodePluginInfo, 'pluginType'> }): FlowNodePlugin {\n const newConfig = config as FlowNodePlugin\n newConfig.pluginInfo.pluginType = 'flowNode';\n return newConfig;\n}\n"],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.es.js
CHANGED
|
@@ -1,181 +1,158 @@
|
|
|
1
|
-
function
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
function createStoragePluginConfig(e) {
|
|
2
|
+
let r = e;
|
|
3
|
+
return r.pluginInfo.pluginType = "storage", r;
|
|
4
4
|
}
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
5
|
+
const stringVariable = [
|
|
6
|
+
{
|
|
7
|
+
label: "年",
|
|
8
|
+
value: "{YY}",
|
|
9
|
+
demo: () => (/* @__PURE__ */ new Date()).getFullYear().toString(),
|
|
10
|
+
format: (e) => (/* @__PURE__ */ new Date()).getFullYear().toString()
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
label: "年",
|
|
14
|
+
value: "{Y}",
|
|
15
|
+
demo: () => (/* @__PURE__ */ new Date()).getFullYear().toString().substring(2),
|
|
16
|
+
format: (e) => (/* @__PURE__ */ new Date()).getFullYear().toString().substring(2)
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
label: "月",
|
|
20
|
+
value: "{M}",
|
|
21
|
+
demo: () => /* @__PURE__ */ ((/* @__PURE__ */ new Date()).getMonth() + 1).toString().padStart(2, "0"),
|
|
22
|
+
format: (e) => /* @__PURE__ */ ((/* @__PURE__ */ new Date()).getMonth() + 1).toString().padStart(2, "0")
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
label: "日",
|
|
26
|
+
value: "{D}",
|
|
27
|
+
demo: () => (/* @__PURE__ */ new Date()).getDate().toString().padStart(2, "0"),
|
|
28
|
+
format: (e) => (/* @__PURE__ */ new Date()).getDate().toString().padStart(2, "0")
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
label: "时",
|
|
32
|
+
value: "{h}",
|
|
33
|
+
demo: () => (/* @__PURE__ */ new Date()).getHours().toString().padStart(2, "0"),
|
|
34
|
+
format: (e) => (/* @__PURE__ */ new Date()).getHours().toString().padStart(2, "0")
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
label: "分",
|
|
38
|
+
value: "{m}",
|
|
39
|
+
demo: () => (/* @__PURE__ */ new Date()).getMinutes().toString().padStart(2, "0"),
|
|
40
|
+
format: (e) => (/* @__PURE__ */ new Date()).getMinutes().toString().padStart(2, "0")
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
label: "秒",
|
|
44
|
+
value: "{s}",
|
|
45
|
+
demo: () => (/* @__PURE__ */ new Date()).getSeconds().toString().padStart(2, "0"),
|
|
46
|
+
format: () => (/* @__PURE__ */ new Date()).getSeconds().toString().padStart(2, "0")
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
label: "毫秒",
|
|
50
|
+
value: "{ss}",
|
|
51
|
+
demo: () => (/* @__PURE__ */ new Date()).getMilliseconds().toString().padStart(3, "0"),
|
|
52
|
+
format: (e) => (/* @__PURE__ */ new Date()).getMilliseconds().toString().padStart(3, "0")
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
label: "时间戳",
|
|
56
|
+
value: "{timestamp}",
|
|
57
|
+
width: 300,
|
|
58
|
+
demo: () => Date.now(),
|
|
59
|
+
format: (e) => Date.now().toString()
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
label: "文件名称",
|
|
63
|
+
value: "{filename}",
|
|
64
|
+
width: 200,
|
|
65
|
+
demo: () => "文本",
|
|
66
|
+
format: (e) => e.fileName
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
label: "后缀",
|
|
70
|
+
value: "{suffix}",
|
|
71
|
+
width: 200,
|
|
72
|
+
demo: () => "txt",
|
|
73
|
+
format: (e) => e.suffix
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
label: "全文件名",
|
|
77
|
+
value: "{allFilename}",
|
|
78
|
+
width: 300,
|
|
79
|
+
demo: () => "文本.txt",
|
|
80
|
+
format: (e) => e.allFileName
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
label: "场景名称",
|
|
84
|
+
value: "{sceneName}",
|
|
85
|
+
width: 300,
|
|
86
|
+
demo: () => "测试场景",
|
|
87
|
+
format: (e) => e.sceneName || ""
|
|
88
|
+
},
|
|
89
|
+
{
|
|
90
|
+
label: "随机字符串",
|
|
91
|
+
value: "{rand(5)}",
|
|
92
|
+
width: 300,
|
|
93
|
+
demo: () => generateRandomString(5),
|
|
94
|
+
format: (e) => generateRandomString(5)
|
|
95
|
+
}
|
|
96
96
|
];
|
|
97
|
-
function
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
r += e.charAt(Math.floor(Math.random() * e.length));
|
|
102
|
-
return r;
|
|
97
|
+
function generateRandomString(e) {
|
|
98
|
+
let r = "";
|
|
99
|
+
for (let i = 0; i < e; i++) r += "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789".charAt(Math.floor(Math.random() * 62));
|
|
100
|
+
return r;
|
|
103
101
|
}
|
|
104
|
-
function
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
const r = /\{rand\((\d+)\)\}/g;
|
|
110
|
-
return t = t.replace(r, (a, n) => {
|
|
111
|
-
const o = parseInt(n, 10);
|
|
112
|
-
return l(o);
|
|
113
|
-
}), t;
|
|
102
|
+
function filePathFormat(e, a) {
|
|
103
|
+
return console.log("filePathFormat", e, a), stringVariable.forEach((r) => {
|
|
104
|
+
let i = r.format(a) || "", o = new RegExp(r.value, "g");
|
|
105
|
+
e = e.replace(o, i);
|
|
106
|
+
}), e = e.replace(/\{rand\((\d+)\)\}/g, (e, r) => generateRandomString(parseInt(r, 10))), e;
|
|
114
107
|
}
|
|
115
|
-
class
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
verifyConfig(e) {
|
|
159
|
-
return Promise.resolve(void 0);
|
|
160
|
-
}
|
|
161
|
-
readConfig(e) {
|
|
162
|
-
const r = `storageSource/${e}`;
|
|
163
|
-
return utools.dbCryptoStorage.getItem(r);
|
|
164
|
-
}
|
|
165
|
-
saveConfig(e, r) {
|
|
166
|
-
const a = `storageSource/${e}`;
|
|
167
|
-
utools.dbCryptoStorage.setItem(a, r);
|
|
168
|
-
}
|
|
169
|
-
/**
|
|
170
|
-
* 插件被卸载
|
|
171
|
-
*/
|
|
172
|
-
uninstall() {
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
export {
|
|
176
|
-
s as StoragePlugIn,
|
|
177
|
-
i as createStoragePlugInConfig,
|
|
178
|
-
g as filePathFormat,
|
|
179
|
-
u as stringVariable
|
|
108
|
+
var StoragePlugin = class {
|
|
109
|
+
init() {
|
|
110
|
+
this.doInit();
|
|
111
|
+
}
|
|
112
|
+
destroy() {
|
|
113
|
+
this.doDestroy();
|
|
114
|
+
}
|
|
115
|
+
deleteFile(e) {
|
|
116
|
+
return Promise.resolve(!1);
|
|
117
|
+
}
|
|
118
|
+
formatUploadPath(e, r) {
|
|
119
|
+
return filePathFormat(e, r);
|
|
120
|
+
}
|
|
121
|
+
extractImagePath(e) {
|
|
122
|
+
try {
|
|
123
|
+
return new URL(e).pathname;
|
|
124
|
+
} catch {
|
|
125
|
+
let r = e.match(/https?:\/\/[^\/]+(\/.*)/);
|
|
126
|
+
return r ? r[1] : "";
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
verifyConfig(e) {
|
|
130
|
+
return Promise.resolve(void 0);
|
|
131
|
+
}
|
|
132
|
+
readConfig(e) {
|
|
133
|
+
let r = `storageSource/${e}`;
|
|
134
|
+
return utools.dbCryptoStorage.getItem(r);
|
|
135
|
+
}
|
|
136
|
+
saveConfig(e, r) {
|
|
137
|
+
let i = `storageSource/${e}`;
|
|
138
|
+
utools.dbCryptoStorage.setItem(i, r);
|
|
139
|
+
}
|
|
140
|
+
uninstall() {}
|
|
141
|
+
};
|
|
142
|
+
const pluginTypeDict = {
|
|
143
|
+
storage: {
|
|
144
|
+
name: "存储",
|
|
145
|
+
icon: "i-u-cloud-storage"
|
|
146
|
+
},
|
|
147
|
+
flowNode: {
|
|
148
|
+
name: "流程",
|
|
149
|
+
icon: "i-u-flow"
|
|
150
|
+
}
|
|
180
151
|
};
|
|
181
|
-
|
|
152
|
+
function createFlowNodePluginConfig(e) {
|
|
153
|
+
let r = e;
|
|
154
|
+
return r.pluginInfo.pluginType = "flowNode", r;
|
|
155
|
+
}
|
|
156
|
+
export { StoragePlugin, createFlowNodePluginConfig, createStoragePluginConfig, filePathFormat, pluginTypeDict, stringVariable };
|
|
157
|
+
|
|
158
|
+
//# sourceMappingURL=index.es.js.map
|
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":["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","names":["pluginTypeDict: Record<PluginType, Record<string, string>>"],"sources":["../src/storage/StoragePluginConfig.ts","../src/utils/StrTemplateUtils.ts","../src/storage/StoragePlugin.ts","../src/core/PluginInfo.ts","../src/flowNode/FlowNodePlugin.ts"],"sourcesContent":["// 从 types 包导入并重新导出\nexport type {\n StorageUIFormElement,\n StorageUIConfig,\n StoragePluginInfo,\n StoragePluginConfig,\n} from '@xiaou66/picture-types'\n\nimport type { StoragePluginConfig, StoragePluginInfo } from '@xiaou66/picture-types'\n\n/**\n * 存储插件配置\n * @param config\n */\nexport function createStoragePluginConfig(config: Omit<StoragePluginConfig, 'pluginInfo'> & { pluginInfo: Omit<StoragePluginInfo, '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 type { IDeleteFileParams, IUploadFileParams, IUploadFileResult, UploadFileOptions } from '@xiaou66/picture-types'\nimport { filePathFormat } from '../utils'\n\n// 重新导出 UploadFileOptions\nexport type { UploadFileOptions } from '@xiaou66/picture-types'\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 * @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","// 从 types 包导入并重新导出\nexport type { PluginType, PluginInfo, PluginConfig } from '@xiaou66/picture-types'\nimport type { PluginType } from '@xiaou66/picture-types'\n\nexport const pluginTypeDict: Record<PluginType, Record<string, string>> = {\n 'storage': {\n name: '存储',\n icon: 'i-u-cloud-storage',\n },\n 'flowNode': {\n name: '流程',\n icon: 'i-u-flow'\n },\n}\n","// 从 types 包导入并重新导出\nexport type {\n FlowNodePluginInfo,\n FlowNodePlugin,\n IFlowContext,\n IFlowNodeActions,\n // 以下类型在 types 包的其他文件中定义,这里也重新导出以保持兼容\n FileUpdateInfoItem,\n SceneInfoItem,\n FileUploadInfo,\n FileLibraryInfo,\n FileLibraryItem,\n IFlowNode,\n IFlowItem,\n} from '@xiaou66/picture-types'\n\nimport type { FlowNodePlugin, FlowNodePluginInfo } from '@xiaou66/picture-types'\n\n/**\n * 流程节点插件配置\n * @param config\n */\nexport function createFlowNodePluginConfig(config: Omit<FlowNodePlugin, 'pluginInfo'> & { pluginInfo: Omit<FlowNodePluginInfo, 'pluginType'> }): FlowNodePlugin {\n const newConfig = config as FlowNodePlugin\n newConfig.pluginInfo.pluginType = 'flowNode';\n return newConfig;\n}\n"],"mappings":"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"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { IDeleteFileParams, IUploadFileParams, IUploadFileResult } from '
|
|
1
|
+
import { IDeleteFileParams, IUploadFileParams, IUploadFileResult, UploadFileOptions } from '@xiaou66/picture-types';
|
|
2
|
+
export type { UploadFileOptions } from '@xiaou66/picture-types';
|
|
2
3
|
/**
|
|
3
4
|
* 插件接口
|
|
4
5
|
*/
|
|
5
|
-
interface
|
|
6
|
+
interface IStoragePlugin {
|
|
6
7
|
/**
|
|
7
8
|
* 插件初始化调用
|
|
8
9
|
*/
|
|
@@ -13,13 +14,10 @@ interface IStoragePlugIn {
|
|
|
13
14
|
destroy(): void;
|
|
14
15
|
}
|
|
15
16
|
type ErrorCallbackType = (name: string, action: string, error: Error) => void;
|
|
16
|
-
export interface UploadFileOptions {
|
|
17
|
-
onProgress?: (progress: number) => void;
|
|
18
|
-
}
|
|
19
17
|
/**
|
|
20
18
|
* 存储插件
|
|
21
19
|
*/
|
|
22
|
-
export declare abstract class
|
|
20
|
+
export declare abstract class StoragePlugin<C = any, E = any> implements IStoragePlugin {
|
|
23
21
|
init(): void;
|
|
24
22
|
/**
|
|
25
23
|
* 初始化使用 <br/>
|
|
@@ -72,4 +70,3 @@ export declare abstract class StoragePlugIn<C = any, E = any> implements IStorag
|
|
|
72
70
|
*/
|
|
73
71
|
uninstall(): void;
|
|
74
72
|
}
|
|
75
|
-
export {};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { StoragePluginConfig, StoragePluginInfo } from '@xiaou66/picture-types';
|
|
2
|
+
export type { StorageUIFormElement, StorageUIConfig, StoragePluginInfo, StoragePluginConfig, } from '@xiaou66/picture-types';
|
|
3
|
+
/**
|
|
4
|
+
* 存储插件配置
|
|
5
|
+
* @param config
|
|
6
|
+
*/
|
|
7
|
+
export declare function createStoragePluginConfig(config: Omit<StoragePluginConfig, 'pluginInfo'> & {
|
|
8
|
+
pluginInfo: Omit<StoragePluginInfo, 'pluginType'>;
|
|
9
|
+
}): StoragePluginConfig;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type { IUploadFileResult, IUploadFileParams, IDeleteFileParams, } from '@xiaou66/picture-types';
|
package/dist/storage/index.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from './
|
|
2
|
-
export * from './
|
|
3
|
-
export * from './
|
|
1
|
+
export * from './StoragePluginConfig';
|
|
2
|
+
export * from './StoragePlugin';
|
|
3
|
+
export * from './StoragePluginType';
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xiaou66/picture-plugin",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.47",
|
|
4
4
|
"description": "Picture bed plugin system",
|
|
5
5
|
"main": "./dist/index.cjs.js",
|
|
6
6
|
"module": "./dist/index.es.js",
|
|
@@ -21,8 +21,15 @@
|
|
|
21
21
|
"license": "ISC",
|
|
22
22
|
"devDependencies": {
|
|
23
23
|
"typescript": "^5.0.0",
|
|
24
|
-
"vite": "
|
|
25
|
-
"vite-plugin-dts": "^4.5.0"
|
|
24
|
+
"vite": "npm:rolldown-vite@^7.2.11",
|
|
25
|
+
"vite-plugin-dts": "^4.5.0",
|
|
26
|
+
"vue": "^3.5.18"
|
|
27
|
+
},
|
|
28
|
+
"dependencies": {
|
|
29
|
+
"@xiaou66/picture-types": "workspace:^"
|
|
30
|
+
},
|
|
31
|
+
"peerDependencies": {
|
|
32
|
+
"vue": "^3.0.0"
|
|
26
33
|
},
|
|
27
34
|
"exports": {
|
|
28
35
|
".": {
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 插件信息
|
|
3
|
-
*/
|
|
4
|
-
export interface PlugInfo {
|
|
5
|
-
/**
|
|
6
|
-
* 插件 code 全局唯一
|
|
7
|
-
*/
|
|
8
|
-
pluginCode: string;
|
|
9
|
-
/**
|
|
10
|
-
* 插件名称
|
|
11
|
-
*/
|
|
12
|
-
pluginName: string;
|
|
13
|
-
/**
|
|
14
|
-
* 插件版本
|
|
15
|
-
*/
|
|
16
|
-
pluginVersion: string;
|
|
17
|
-
/**
|
|
18
|
-
* 插件作者
|
|
19
|
-
*/
|
|
20
|
-
pluginAuthor: string;
|
|
21
|
-
/**
|
|
22
|
-
* 插件描述
|
|
23
|
-
*/
|
|
24
|
-
pluginDesc: string;
|
|
25
|
-
/**
|
|
26
|
-
* 插件类型
|
|
27
|
-
*/
|
|
28
|
-
pluginType: 'storage' | 'flowNode';
|
|
29
|
-
/**
|
|
30
|
-
* 插件 logo
|
|
31
|
-
*/
|
|
32
|
-
pluginLogo: string;
|
|
33
|
-
}
|
|
@@ -1,196 +0,0 @@
|
|
|
1
|
-
import { AsyncComponentLoader, AsyncComponentOptions } from 'vue';
|
|
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
|
-
export interface FlowNodePlugInfo extends PlugInfo {
|
|
32
|
-
/**
|
|
33
|
-
* 插件分组
|
|
34
|
-
*/
|
|
35
|
-
pluginGroup: 'image' | 'music' | 'video' | 'other' | 'trigger' | 'common' | 'finish';
|
|
36
|
-
}
|
|
37
|
-
export interface FlowNodePlugIn {
|
|
38
|
-
/**
|
|
39
|
-
* 无需配置可以直接使用
|
|
40
|
-
*/
|
|
41
|
-
noConfig?: boolean;
|
|
42
|
-
pluginInfo: FlowNodePlugInfo;
|
|
43
|
-
/**
|
|
44
|
-
* 自定义配置 UI 如果配置这个 {@link uiConfig} 配置将无效
|
|
45
|
-
*/
|
|
46
|
-
uiConfigComponent?: AsyncComponentLoader;
|
|
47
|
-
}
|
|
48
|
-
interface FileUpdateInfoItem {
|
|
49
|
-
id: string;
|
|
50
|
-
/**
|
|
51
|
-
* 文件路径
|
|
52
|
-
*/
|
|
53
|
-
filePath: string;
|
|
54
|
-
/**
|
|
55
|
-
* 放 base64 的
|
|
56
|
-
*/
|
|
57
|
-
content?: string;
|
|
58
|
-
/**
|
|
59
|
-
* 文件名称
|
|
60
|
-
*/
|
|
61
|
-
fileName: string;
|
|
62
|
-
/**
|
|
63
|
-
* 文件后缀
|
|
64
|
-
*/
|
|
65
|
-
fileSuffix: string;
|
|
66
|
-
/**
|
|
67
|
-
* 是否临时文件, 即 base64 文件
|
|
68
|
-
*/
|
|
69
|
-
tempFile?: boolean;
|
|
70
|
-
/**
|
|
71
|
-
* 文件大小
|
|
72
|
-
*/
|
|
73
|
-
fileSize: number;
|
|
74
|
-
/**
|
|
75
|
-
* 场景名称
|
|
76
|
-
*/
|
|
77
|
-
sceneName?: string;
|
|
78
|
-
/**
|
|
79
|
-
* 上传方式
|
|
80
|
-
*/
|
|
81
|
-
uploadWay: string;
|
|
82
|
-
/**
|
|
83
|
-
* 上传状态
|
|
84
|
-
*/
|
|
85
|
-
uploadStatus: 'waiting' | 'uploading' | 'failed';
|
|
86
|
-
progress?: number;
|
|
87
|
-
}
|
|
88
|
-
interface SceneInfoItem {
|
|
89
|
-
id: string;
|
|
90
|
-
/**
|
|
91
|
-
* 场景名称
|
|
92
|
-
*/
|
|
93
|
-
sceneName: string;
|
|
94
|
-
/**
|
|
95
|
-
* 是否启用
|
|
96
|
-
*/
|
|
97
|
-
enable: boolean;
|
|
98
|
-
}
|
|
99
|
-
interface FileUploadInfo {
|
|
100
|
-
/**
|
|
101
|
-
* 存储源 id
|
|
102
|
-
*/
|
|
103
|
-
storageId: string;
|
|
104
|
-
/**
|
|
105
|
-
* URL
|
|
106
|
-
*/
|
|
107
|
-
url: string;
|
|
108
|
-
/**
|
|
109
|
-
* 额外数据
|
|
110
|
-
*/
|
|
111
|
-
extra: any;
|
|
112
|
-
}
|
|
113
|
-
export interface FileLibraryInfo {
|
|
114
|
-
/**
|
|
115
|
-
* 文件名称
|
|
116
|
-
*/
|
|
117
|
-
fileName: string;
|
|
118
|
-
/**
|
|
119
|
-
* 文件后缀
|
|
120
|
-
*/
|
|
121
|
-
fileSuffix: string;
|
|
122
|
-
/**
|
|
123
|
-
* 文件大小
|
|
124
|
-
*/
|
|
125
|
-
fileSize: number;
|
|
126
|
-
}
|
|
127
|
-
interface FileLibraryItem {
|
|
128
|
-
/**
|
|
129
|
-
* id
|
|
130
|
-
*/
|
|
131
|
-
id: string;
|
|
132
|
-
/**
|
|
133
|
-
* 分组 id
|
|
134
|
-
*/
|
|
135
|
-
fileBoxId: string;
|
|
136
|
-
/**
|
|
137
|
-
* 文件保存实际的 docId
|
|
138
|
-
*/
|
|
139
|
-
fileFileBoxDocId?: string;
|
|
140
|
-
/**
|
|
141
|
-
* 场景 id
|
|
142
|
-
*/
|
|
143
|
-
sceneId: string;
|
|
144
|
-
/**
|
|
145
|
-
* 上传文件信息
|
|
146
|
-
*/
|
|
147
|
-
fileUploadInfoList: FileUploadInfo[];
|
|
148
|
-
/**
|
|
149
|
-
* 文件信息
|
|
150
|
-
*/
|
|
151
|
-
fileInfo: FileLibraryInfo;
|
|
152
|
-
/**
|
|
153
|
-
* 标签分组 id
|
|
154
|
-
*/
|
|
155
|
-
tags?: string[];
|
|
156
|
-
/**
|
|
157
|
-
* 创建时间
|
|
158
|
-
*/
|
|
159
|
-
createTime: number;
|
|
160
|
-
}
|
|
161
|
-
interface IFlowNode<T = any> {
|
|
162
|
-
id: string;
|
|
163
|
-
nodeCode: string;
|
|
164
|
-
nodeData: T | Record<string, any>;
|
|
165
|
-
}
|
|
166
|
-
interface IFlowItem {
|
|
167
|
-
id: string;
|
|
168
|
-
nodeList: IFlowNode[];
|
|
169
|
-
createAt: number;
|
|
170
|
-
updateAt: number;
|
|
171
|
-
}
|
|
172
|
-
export interface IFlowContext {
|
|
173
|
-
uploadFile: FileUpdateInfoItem;
|
|
174
|
-
fileLibrary: FileLibraryItem;
|
|
175
|
-
sceneInfo: SceneInfoItem;
|
|
176
|
-
context?: Record<string, any>;
|
|
177
|
-
}
|
|
178
|
-
export interface IFlowNodeActions<T> {
|
|
179
|
-
execute?: (flow: IFlowItem, flowData: IFlowNode<T>, data: IFlowContext) => Promise<void>;
|
|
180
|
-
onSaveData?: (flow: IFlowItem, flowData: IFlowNode<T>) => void;
|
|
181
|
-
onDestroy?: (flow: IFlowItem, flowData: IFlowNode<T>) => void;
|
|
182
|
-
adjustData?: (flow: IFlowItem, flowData: IFlowNode<T>) => Promise<boolean>;
|
|
183
|
-
}
|
|
184
|
-
/**
|
|
185
|
-
* 流程节点插件配置
|
|
186
|
-
* @param config
|
|
187
|
-
*/
|
|
188
|
-
export declare function createFlowNodePlugInConfig(config: Omit<FlowNodePlugIn, 'pluginInfo'> & {
|
|
189
|
-
pluginInfo: Omit<FlowNodePlugInfo, 'pluginType'>;
|
|
190
|
-
}): FlowNodePlugIn;
|
|
191
|
-
/**
|
|
192
|
-
* 创建流程节点插件
|
|
193
|
-
* @param actions
|
|
194
|
-
*/
|
|
195
|
-
export declare function createFlowNodePlugInActions<T>(actions: IFlowNodeActions<T>): IFlowNodeActions<T>;
|
|
196
|
-
export {};
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { AsyncComponentLoader, AsyncComponentOptions } from 'vue';
|
|
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
|
-
/**
|
|
32
|
-
* 插件信息
|
|
33
|
-
*/
|
|
34
|
-
export interface StoragePlugInfo extends PlugInfo {
|
|
35
|
-
/**
|
|
36
|
-
* 插件分组
|
|
37
|
-
*/
|
|
38
|
-
pluginGroup: 'cloudVendor' | 'self' | 'other';
|
|
39
|
-
}
|
|
40
|
-
export interface StoragePlugInConfig {
|
|
41
|
-
/**
|
|
42
|
-
* 无需配置可以直接使用
|
|
43
|
-
*/
|
|
44
|
-
noConfig?: boolean;
|
|
45
|
-
pluginInfo: StoragePlugInfo;
|
|
46
|
-
/**
|
|
47
|
-
* 配置 ui
|
|
48
|
-
*/
|
|
49
|
-
uiConfig?: StorageUIConfig;
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* 存储插件配置
|
|
53
|
-
* @param config
|
|
54
|
-
*/
|
|
55
|
-
export declare function createStoragePlugInConfig(config: Omit<StoragePlugInConfig, 'pluginInfo'> & {
|
|
56
|
-
pluginInfo: Omit<StoragePlugInfo, 'pluginType'>;
|
|
57
|
-
}): StoragePlugInConfig;
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
export interface IUploadFileResult<E = any> {
|
|
2
|
-
/**
|
|
3
|
-
* 上传后文件访问地址
|
|
4
|
-
*/
|
|
5
|
-
url: string;
|
|
6
|
-
/**
|
|
7
|
-
* 缩略图地址
|
|
8
|
-
*/
|
|
9
|
-
thumbnailUrl?: string;
|
|
10
|
-
/**
|
|
11
|
-
* 额外数据
|
|
12
|
-
*/
|
|
13
|
-
extra?: E;
|
|
14
|
-
}
|
|
15
|
-
export interface IUploadFileParams {
|
|
16
|
-
/**
|
|
17
|
-
* 上传 id
|
|
18
|
-
*/
|
|
19
|
-
readonly id: string;
|
|
20
|
-
/**
|
|
21
|
-
* 配置 id
|
|
22
|
-
*/
|
|
23
|
-
readonly storageId: string;
|
|
24
|
-
/**
|
|
25
|
-
* 配置名称
|
|
26
|
-
*/
|
|
27
|
-
readonly sceneName: string;
|
|
28
|
-
/**
|
|
29
|
-
* 文件路径
|
|
30
|
-
*/
|
|
31
|
-
readonly filePath: string;
|
|
32
|
-
/**
|
|
33
|
-
* 全文件名称
|
|
34
|
-
*/
|
|
35
|
-
readonly allFileName: string;
|
|
36
|
-
/**
|
|
37
|
-
* 文件名称
|
|
38
|
-
*/
|
|
39
|
-
readonly fileName: string;
|
|
40
|
-
/**
|
|
41
|
-
* 文件后缀
|
|
42
|
-
*/
|
|
43
|
-
readonly suffix: string;
|
|
44
|
-
/**
|
|
45
|
-
* 文件大小
|
|
46
|
-
*/
|
|
47
|
-
readonly fileSize: number;
|
|
48
|
-
/**
|
|
49
|
-
* 文件
|
|
50
|
-
*/
|
|
51
|
-
readonly file?: File;
|
|
52
|
-
}
|
|
53
|
-
/**
|
|
54
|
-
* 删除参数
|
|
55
|
-
*/
|
|
56
|
-
export interface IDeleteFileParams<E = any> {
|
|
57
|
-
storageId: string;
|
|
58
|
-
/**
|
|
59
|
-
* 额外数据
|
|
60
|
-
*/
|
|
61
|
-
extra?: E;
|
|
62
|
-
}
|