@xiaou66/picture-plugin 0.0.54 → 0.0.55
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs.js","names":["pluginTypeDict: Record<PluginType, Record<string, string>>"],"sources":["../src/storage/StoragePluginConfig.ts","../src/utils/StrTemplateUtils.ts","../src/utils/FlowUtils.ts","../src/utils/utils.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 { IFlowContext } from '@xiaou66/picture-types'\n\n/**\n * 替换上传文件\n * @param ctx 流程上下文\n * @param filePath 替换的文件路径\n */\nexport function replaceUploadFile(ctx: IFlowContext, filePath: string) {\n const uploadFile = ctx.uploadFile\n //@ts-ignore;\n const existsSync = window.fs.existsSync(tempPath)\n if (!existsSync) {\n throw new Error('replaceUploadFile--文件不存在--' + filePath);\n }\n uploadFile.tempFile = true\n //@ts-ignore;\n uploadFile.filePath = window.path.join(utools.getPath('downloads'), 'test.webp')\n // @ts-ignore\n uploadFile.fileName = window.path.basename(tempPath)\n // @ts-ignore\n const stats = window.fs.statSync(tempPath)\n uploadFile.fileSize = stats.size\n}\n\nexport default {\n replaceUploadFile,\n}\n","/**\n * 获取临时存储路径\n * 用于保存上传前的临时文件\n * @returns {string} 临时存储路径\n */\nexport function getDataTempSavePath(): string {\n return (\n utools.dbStorage.getItem(`settingUserStore/localAppData/${utools.getNativeId()}`) ||\n // @ts-ignore\n window.path.join(utools.getPath('userData'), 'app', 'picture-bed-plus', 'temps')\n )\n}\n\nexport default {\n getDataTempSavePath,\n}\n","import type { IDeleteFileParams, IUploadFileParams, IUploadFileResult, UploadFileOptions } from '@xiaou66/picture-types'\nimport { filePathFormat } from '../utils'\nimport { createFlowNodeActions } from '../flowNode'\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\n// @unocss-include\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 FlowNodePluginConfig,\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 {\n FlowNodePluginConfig,\n FlowNodePluginInfo,\n IFlowNodeActions,\n IFlowItem,\n IFlowNode,\n IFlowContext\n} from '@xiaou66/picture-types'\n\n/**\n * 流程节点插件配置\n * @param config\n */\nexport function createFlowNodePluginConfig(config: Omit<FlowNodePluginConfig, 'pluginInfo'> & { pluginInfo: Omit<FlowNodePluginInfo, 'pluginType'> }): FlowNodePluginConfig {\n const newConfig = config as FlowNodePluginConfig\n newConfig.pluginInfo.pluginType = 'flowNode';\n return newConfig;\n}\n\n\n/**\n * 流程节点插件抽象基类\n * @template T 节点数据类型\n *\n * @example\n * ```typescript\n * class ImageCompressPlugin extends FlowNodePlugin<{ quality: number }> {\n * readonly info = {\n * pluginCode: 'image-compress',\n * pluginName: '图片压缩',\n * pluginGroup: 'image',\n * // ...其他插件信息\n * }\n *\n * async onExecute(flow, flowData, data) {\n * const { quality } = flowData.nodeData\n * // 压缩逻辑\n * }\n *\n * onDestroy(flow, flowData) {\n * // 清理资源\n * }\n * }\n *\n * const actions = createFlowNodeActions(new ImageCompressPlugin())\n * ```\n */\nexport abstract class FlowNodePlugin<T = any> implements IFlowNodeActions<T> {\n /**\n * 执行节点核心逻辑\n * @param flow 流程项\n * @param flowData 流程节点数据\n * @param data 流程上下文\n */\n abstract onExecute(flow: IFlowItem, flowData: IFlowNode<T>, data: IFlowContext): Promise<void>\n\n /**\n * 保存数据后的钩子(可选)\n * @param flow 流程项\n * @param flowData 流程节点数据\n */\n onAfterSave?(flow: IFlowItem, flowData: IFlowNode<T>): void\n\n /**\n * 节点销毁时的清理钩子(可选)\n * @param flow 流程项\n * @param flowData 流程节点数据\n */\n onDestroy?(flow: IFlowItem, flowData: IFlowNode<T>): void\n}\n\n\n/**\n * 创建流程节点动作配置\n * @param input 流程节点动作配置或 FlowNodePlugin 实例\n *\n * @example\n * // 方式1: 函数式配置(保持兼容)\n * const actions = createFlowNodeActions({\n * onExecute: async (flow, flowData, data) => {\n * // 逻辑\n * }\n * })\n *\n * @example\n * // 方式2: 类实例\n * const actions = createFlowNodeActions(new MyFlowNodePlugin())\n */\nexport function createFlowNodeActions<T>(input: IFlowNodeActions<T> | FlowNodePlugin<T>): IFlowNodeActions<T> {\n // FlowNodePlugin 实现了 IFlowNodeActions,可直接返回\n return input\n}\n"],"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/utils/FlowUtils.ts","../src/utils/utils.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 { IFlowContext } from '@xiaou66/picture-types'\n\n/**\n * 替换上传文件\n * @param ctx 流程上下文\n * @param filePath 替换的文件路径\n */\nexport function replaceUploadFile(ctx: IFlowContext, filePath: string) {\n const uploadFile = ctx.uploadFile\n //@ts-ignore;\n const existsSync = window.fs.existsSync(tempPath)\n if (!existsSync) {\n throw new Error('replaceUploadFile--文件不存在--' + filePath);\n }\n uploadFile.tempFile = true\n //@ts-ignore;\n uploadFile.filePath = window.path.join(utools.getPath('downloads'), 'test.webp')\n // @ts-ignore\n uploadFile.fileName = window.path.basename(tempPath)\n // @ts-ignore\n const stats = window.fs.statSync(tempPath)\n uploadFile.fileSize = stats.size\n}\n\nexport default {\n replaceUploadFile,\n}\n","/**\n * 获取临时存储路径\n * 用于保存上传前的临时文件\n * @returns {string} 临时存储路径\n */\nexport function getDataTempSavePath(): string {\n return (\n utools.dbStorage.getItem(`settingUserStore/localAppData/${utools.getNativeId()}`) ||\n // @ts-ignore\n window.path.join(utools.getPath('userData'), 'app', 'picture-bed-plus', 'temps')\n )\n}\n\nexport default {\n getDataTempSavePath,\n}\n","import type { IDeleteFileParams, IUploadFileParams, IUploadFileResult, UploadFileOptions } from '@xiaou66/picture-types'\nimport { filePathFormat } from '../utils'\nimport { createFlowNodeActions } from '../flowNode'\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\n// @unocss-include\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 FlowNodePluginConfig,\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 {\n FlowNodePluginConfig,\n FlowNodePluginInfo,\n IFlowNodeActions,\n IFlowItem,\n IFlowNode,\n IFlowContext\n} from '@xiaou66/picture-types'\n\n/**\n * 流程节点插件配置\n * @param config\n */\nexport function createFlowNodePluginConfig(config: Omit<FlowNodePluginConfig, 'pluginInfo'> & { pluginInfo: Omit<FlowNodePluginInfo, 'pluginType'> }): FlowNodePluginConfig {\n const newConfig = config as FlowNodePluginConfig\n newConfig.pluginInfo.pluginType = 'flowNode';\n return newConfig;\n}\n\n\n/**\n * 流程节点插件抽象基类\n * @template T 节点数据类型\n *\n * @example\n * ```typescript\n * class ImageCompressPlugin extends FlowNodePlugin<{ quality: number }> {\n * readonly info = {\n * pluginCode: 'image-compress',\n * pluginName: '图片压缩',\n * pluginGroup: 'image',\n * // ...其他插件信息\n * }\n *\n * async onExecute(ctx, flow, flowData) {\n * const { quality } = flowData.nodeData\n * // 压缩逻辑\n * }\n *\n * onDestroy(flow, flowData) {\n * // 清理资源\n * }\n * }\n *\n * const actions = createFlowNodeActions(new ImageCompressPlugin())\n * ```\n */\nexport abstract class FlowNodePlugin<T = any> implements IFlowNodeActions<T> {\n /**\n * 执行节点核心逻辑\n * @param ctx 流程上下文\n * @param flow 流程项\n * @param flowData 流程节点数据\n */\n abstract onExecute(ctx: IFlowContext, flow: IFlowItem, flowData: IFlowNode<T>): Promise<void>\n\n /**\n * 保存数据后的钩子(可选)\n * @param flow 流程项\n * @param flowData 流程节点数据\n */\n onAfterSave?(flow: IFlowItem, flowData: IFlowNode<T>): void\n\n /**\n * 节点销毁时的清理钩子(可选)\n * @param flow 流程项\n * @param flowData 流程节点数据\n */\n onDestroy?(flow: IFlowItem, flowData: IFlowNode<T>): void\n}\n\n\n/**\n * 创建流程节点动作配置\n * @param input 流程节点动作配置或 FlowNodePlugin 实例\n *\n * @example\n * // 方式1: 函数式配置(保持兼容)\n * const actions = createFlowNodeActions({\n * onExecute: async (ctx, flow, flowData) => {\n * // 逻辑\n * }\n * })\n *\n * @example\n * // 方式2: 类实例\n * const actions = createFlowNodeActions(new MyFlowNodePlugin())\n */\nexport function createFlowNodeActions<T>(input: IFlowNodeActions<T> | FlowNodePlugin<T>): IFlowNodeActions<T> {\n // FlowNodePlugin 实现了 IFlowNodeActions,可直接返回\n return input\n}\n"],"mappings":"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"}
|
package/dist/index.es.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.es.js","names":["pluginTypeDict: Record<PluginType, Record<string, string>>"],"sources":["../src/storage/StoragePluginConfig.ts","../src/utils/StrTemplateUtils.ts","../src/utils/FlowUtils.ts","../src/utils/utils.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 { IFlowContext } from '@xiaou66/picture-types'\n\n/**\n * 替换上传文件\n * @param ctx 流程上下文\n * @param filePath 替换的文件路径\n */\nexport function replaceUploadFile(ctx: IFlowContext, filePath: string) {\n const uploadFile = ctx.uploadFile\n //@ts-ignore;\n const existsSync = window.fs.existsSync(tempPath)\n if (!existsSync) {\n throw new Error('replaceUploadFile--文件不存在--' + filePath);\n }\n uploadFile.tempFile = true\n //@ts-ignore;\n uploadFile.filePath = window.path.join(utools.getPath('downloads'), 'test.webp')\n // @ts-ignore\n uploadFile.fileName = window.path.basename(tempPath)\n // @ts-ignore\n const stats = window.fs.statSync(tempPath)\n uploadFile.fileSize = stats.size\n}\n\nexport default {\n replaceUploadFile,\n}\n","/**\n * 获取临时存储路径\n * 用于保存上传前的临时文件\n * @returns {string} 临时存储路径\n */\nexport function getDataTempSavePath(): string {\n return (\n utools.dbStorage.getItem(`settingUserStore/localAppData/${utools.getNativeId()}`) ||\n // @ts-ignore\n window.path.join(utools.getPath('userData'), 'app', 'picture-bed-plus', 'temps')\n )\n}\n\nexport default {\n getDataTempSavePath,\n}\n","import type { IDeleteFileParams, IUploadFileParams, IUploadFileResult, UploadFileOptions } from '@xiaou66/picture-types'\nimport { filePathFormat } from '../utils'\nimport { createFlowNodeActions } from '../flowNode'\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\n// @unocss-include\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 FlowNodePluginConfig,\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 {\n FlowNodePluginConfig,\n FlowNodePluginInfo,\n IFlowNodeActions,\n IFlowItem,\n IFlowNode,\n IFlowContext\n} from '@xiaou66/picture-types'\n\n/**\n * 流程节点插件配置\n * @param config\n */\nexport function createFlowNodePluginConfig(config: Omit<FlowNodePluginConfig, 'pluginInfo'> & { pluginInfo: Omit<FlowNodePluginInfo, 'pluginType'> }): FlowNodePluginConfig {\n const newConfig = config as FlowNodePluginConfig\n newConfig.pluginInfo.pluginType = 'flowNode';\n return newConfig;\n}\n\n\n/**\n * 流程节点插件抽象基类\n * @template T 节点数据类型\n *\n * @example\n * ```typescript\n * class ImageCompressPlugin extends FlowNodePlugin<{ quality: number }> {\n * readonly info = {\n * pluginCode: 'image-compress',\n * pluginName: '图片压缩',\n * pluginGroup: 'image',\n * // ...其他插件信息\n * }\n *\n * async onExecute(flow, flowData, data) {\n * const { quality } = flowData.nodeData\n * // 压缩逻辑\n * }\n *\n * onDestroy(flow, flowData) {\n * // 清理资源\n * }\n * }\n *\n * const actions = createFlowNodeActions(new ImageCompressPlugin())\n * ```\n */\nexport abstract class FlowNodePlugin<T = any> implements IFlowNodeActions<T> {\n /**\n * 执行节点核心逻辑\n * @param flow 流程项\n * @param flowData 流程节点数据\n * @param data 流程上下文\n */\n abstract onExecute(flow: IFlowItem, flowData: IFlowNode<T>, data: IFlowContext): Promise<void>\n\n /**\n * 保存数据后的钩子(可选)\n * @param flow 流程项\n * @param flowData 流程节点数据\n */\n onAfterSave?(flow: IFlowItem, flowData: IFlowNode<T>): void\n\n /**\n * 节点销毁时的清理钩子(可选)\n * @param flow 流程项\n * @param flowData 流程节点数据\n */\n onDestroy?(flow: IFlowItem, flowData: IFlowNode<T>): void\n}\n\n\n/**\n * 创建流程节点动作配置\n * @param input 流程节点动作配置或 FlowNodePlugin 实例\n *\n * @example\n * // 方式1: 函数式配置(保持兼容)\n * const actions = createFlowNodeActions({\n * onExecute: async (flow, flowData, data) => {\n * // 逻辑\n * }\n * })\n *\n * @example\n * // 方式2: 类实例\n * const actions = createFlowNodeActions(new MyFlowNodePlugin())\n */\nexport function createFlowNodeActions<T>(input: IFlowNodeActions<T> | FlowNodePlugin<T>): IFlowNodeActions<T> {\n // FlowNodePlugin 实现了 IFlowNodeActions,可直接返回\n return input\n}\n"],"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/utils/FlowUtils.ts","../src/utils/utils.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 { IFlowContext } from '@xiaou66/picture-types'\n\n/**\n * 替换上传文件\n * @param ctx 流程上下文\n * @param filePath 替换的文件路径\n */\nexport function replaceUploadFile(ctx: IFlowContext, filePath: string) {\n const uploadFile = ctx.uploadFile\n //@ts-ignore;\n const existsSync = window.fs.existsSync(tempPath)\n if (!existsSync) {\n throw new Error('replaceUploadFile--文件不存在--' + filePath);\n }\n uploadFile.tempFile = true\n //@ts-ignore;\n uploadFile.filePath = window.path.join(utools.getPath('downloads'), 'test.webp')\n // @ts-ignore\n uploadFile.fileName = window.path.basename(tempPath)\n // @ts-ignore\n const stats = window.fs.statSync(tempPath)\n uploadFile.fileSize = stats.size\n}\n\nexport default {\n replaceUploadFile,\n}\n","/**\n * 获取临时存储路径\n * 用于保存上传前的临时文件\n * @returns {string} 临时存储路径\n */\nexport function getDataTempSavePath(): string {\n return (\n utools.dbStorage.getItem(`settingUserStore/localAppData/${utools.getNativeId()}`) ||\n // @ts-ignore\n window.path.join(utools.getPath('userData'), 'app', 'picture-bed-plus', 'temps')\n )\n}\n\nexport default {\n getDataTempSavePath,\n}\n","import type { IDeleteFileParams, IUploadFileParams, IUploadFileResult, UploadFileOptions } from '@xiaou66/picture-types'\nimport { filePathFormat } from '../utils'\nimport { createFlowNodeActions } from '../flowNode'\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\n// @unocss-include\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 FlowNodePluginConfig,\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 {\n FlowNodePluginConfig,\n FlowNodePluginInfo,\n IFlowNodeActions,\n IFlowItem,\n IFlowNode,\n IFlowContext\n} from '@xiaou66/picture-types'\n\n/**\n * 流程节点插件配置\n * @param config\n */\nexport function createFlowNodePluginConfig(config: Omit<FlowNodePluginConfig, 'pluginInfo'> & { pluginInfo: Omit<FlowNodePluginInfo, 'pluginType'> }): FlowNodePluginConfig {\n const newConfig = config as FlowNodePluginConfig\n newConfig.pluginInfo.pluginType = 'flowNode';\n return newConfig;\n}\n\n\n/**\n * 流程节点插件抽象基类\n * @template T 节点数据类型\n *\n * @example\n * ```typescript\n * class ImageCompressPlugin extends FlowNodePlugin<{ quality: number }> {\n * readonly info = {\n * pluginCode: 'image-compress',\n * pluginName: '图片压缩',\n * pluginGroup: 'image',\n * // ...其他插件信息\n * }\n *\n * async onExecute(ctx, flow, flowData) {\n * const { quality } = flowData.nodeData\n * // 压缩逻辑\n * }\n *\n * onDestroy(flow, flowData) {\n * // 清理资源\n * }\n * }\n *\n * const actions = createFlowNodeActions(new ImageCompressPlugin())\n * ```\n */\nexport abstract class FlowNodePlugin<T = any> implements IFlowNodeActions<T> {\n /**\n * 执行节点核心逻辑\n * @param ctx 流程上下文\n * @param flow 流程项\n * @param flowData 流程节点数据\n */\n abstract onExecute(ctx: IFlowContext, flow: IFlowItem, flowData: IFlowNode<T>): Promise<void>\n\n /**\n * 保存数据后的钩子(可选)\n * @param flow 流程项\n * @param flowData 流程节点数据\n */\n onAfterSave?(flow: IFlowItem, flowData: IFlowNode<T>): void\n\n /**\n * 节点销毁时的清理钩子(可选)\n * @param flow 流程项\n * @param flowData 流程节点数据\n */\n onDestroy?(flow: IFlowItem, flowData: IFlowNode<T>): void\n}\n\n\n/**\n * 创建流程节点动作配置\n * @param input 流程节点动作配置或 FlowNodePlugin 实例\n *\n * @example\n * // 方式1: 函数式配置(保持兼容)\n * const actions = createFlowNodeActions({\n * onExecute: async (ctx, flow, flowData) => {\n * // 逻辑\n * }\n * })\n *\n * @example\n * // 方式2: 类实例\n * const actions = createFlowNodeActions(new MyFlowNodePlugin())\n */\nexport function createFlowNodeActions<T>(input: IFlowNodeActions<T> | FlowNodePlugin<T>): IFlowNodeActions<T> {\n // FlowNodePlugin 实现了 IFlowNodeActions,可直接返回\n return input\n}\n"],"mappings":"AAcA,SAAgB,0BAA0B,GAA8H;CACtK,IAAM,IAAY;AAElB,QADA,EAAU,WAAW,aAAa,WAC3B;;ACdT,MAAa,iBAAiB;CAC5B;EACE,OAAO;EACP,OAAO;EACP,6BACS,IAAI,MAAM,EAAC,aAAa,CAAC,UAAU;EAE5C,SAAS,uBACA,IAAI,MAAM,EAAC,aAAa,CAAC,UAAU;EAE7C;CACD;EACE,OAAO;EACP,OAAO;EACP,6BACS,IAAI,MAAM,EAAC,aAAa,CAAC,UAAU,CAAC,UAAU,EAAE;EAEzD,SAAS,uBACA,IAAI,MAAM,EAAC,aAAa,CAAC,UAAU,CAAC,UAAU,EAAE;EAE1D;CACD;EACE,OAAO;EACP,OAAO;EACP,YACE,kCAAQ,IAAI,MAAM,EAAC,UAAU,GAAG,GAAG,UAAU,CAAC,SAAS,GAAG,IAAI;EAEhE,SAAS,MACP,kCAAQ,IAAI,MAAM,EAAC,UAAU,GAAG,GAAG,UAAU,CAAC,SAAS,GAAG,IAAI;EAEjE;CACD;EACE,OAAO;EACP,OAAO;EACP,6BACU,IAAI,MAAM,EAAC,SAAS,CAAE,UAAU,CAAC,SAAS,GAAG,IAAI;EAE3D,SAAS,uBACC,IAAI,MAAM,EAAC,SAAS,CAAE,UAAU,CAAC,SAAS,GAAG,IAAI;EAE5D;CACD;EACE,OAAO;EACP,OAAO;EACP,6BACS,IAAI,MAAM,EAAC,UAAU,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI;EAE1D,SAAS,uBACA,IAAI,MAAM,EAAC,UAAU,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI;EAE3D;CACD;EACE,OAAO;EACP,OAAO;EACP,6BACS,IAAI,MAAM,EAAC,YAAY,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI;EAE5D,SAAS,uBACA,IAAI,MAAM,EAAC,YAAY,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI;EAE7D;CACD;EACE,OAAO;EACP,OAAO;EACP,6BACS,IAAI,MAAM,EAAC,YAAY,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI;EAE5D,+BACS,IAAI,MAAM,EAAC,YAAY,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI;EAE7D;CACD;EACE,OAAO;EACP,OAAO;EACP,6BACS,IAAI,MAAM,EAAC,iBAAiB,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI;EAEjE,SAAS,uBACA,IAAI,MAAM,EAAC,iBAAiB,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI;EAElE;CACD;EACE,OAAO;EACP,OAAO;EACP,OAAO;EACP,YACS,KAAK,KAAK;EAEnB,SAAS,MACA,KAAK,KAAK,CAAC,UAAU;EAE/B;CACD;EACE,OAAO;EACP,OAAO;EACP,OAAO;EACP,YACS;EAET,SAAS,MACA,EAAI;EAEd;CACD;EACE,OAAO;EACP,OAAO;EACP,OAAO;EACP,YACS;EAET,SAAS,MACA,EAAI;EAEd;CACD;EACE,OAAO;EACP,OAAO;EACP,OAAO;EACP,YACS;EAET,SAAS,MACA,EAAI;EAEd;CACD;EACE,OAAO;EACP,OAAO;EACP,OAAO;EACP,YACS;EAET,SAAS,MACA,EAAI,aAAa;EAE3B;CACD;EACE,OAAO;EACP,OAAO;EACP,OAAO;EACP,YACS,qBAAqB,EAAE;EAEhC,SAAS,MACA,qBAAqB,EAAE;EAEjC;CACF;AAGD,SAAS,qBAAqB,GAAwB;CACpD,IACI,IAAS;AACb,MAAK,IAAI,IAAI,GAAG,IAAI,GAAQ,IAC1B,MAAU,iEAAM,OAAO,KAAK,MAAM,KAAK,QAAQ,GAAG,GAAa,CAAC;AAElE,QAAO;;AAET,SAAgB,eAAe,GAAa,GAAgC;AAiB1E,QAhBA,QAAQ,IAAI,kBAAkB,GAAK,EAAI,EACvC,eAAe,SAAQ,MAAY;EAEjC,IAAM,IAAQ,EAAS,OAAO,EAAI,IAAI,IAEhC,IAAQ,IAAI,OAAO,EAAS,OAAO,IAAI;AAC7C,MAAM,EAAI,QAAQ,GAAO,EAAM;GAC/B,EAIF,IAAM,EAAI,QADQ,uBACY,GAAO,MAE5B,qBADQ,SAAS,GAAI,GAAG,CACI,CACnC,EAEK;;AC3KT,SAAgB,kBAAkB,GAAmB,GAAkB;CACrE,IAAM,IAAa,EAAI;AAGvB,KAAI,CADe,OAAO,GAAG,WAAW,SAAS,CAE/C,OAAU,MAAM,+BAA+B,EAAS;AAS1D,CAPA,EAAW,WAAW,IAEtB,EAAW,WAAW,OAAO,KAAK,KAAK,OAAO,QAAQ,YAAY,EAAE,YAAY,EAEhF,EAAW,WAAW,OAAO,KAAK,SAAS,SAAS,EAGpD,EAAW,WADG,OAAO,GAAG,SAAS,SAAS,CACd;;AChB9B,SAAgB,sBAA8B;AAC5C,QACE,OAAO,UAAU,QAAQ,iCAAiC,OAAO,aAAa,GAAG,IAEjF,OAAO,KAAK,KAAK,OAAO,QAAQ,WAAW,EAAE,OAAO,oBAAoB,QAAQ;;ACsBpF,IAAsB,gBAAtB,MAAgF;CAE9E,OAAa;AACX,OAAK,QAAQ;;CAUf,UAAU;AACR,OAAK,WAAW;;CAuBlB,WAAkB,GAAgD;AAChE,SAAO,QAAQ,QAAQ,GAAM;;CAS/B,iBAA2B,GAAqB,GAA2B;AACzE,SAAO,eAAe,GAAa,EAAO;;CAQ5C,iBAA2B,GAAqB;AAC9C,MAAI;AAEF,UADe,IAAI,IAAI,EAAI,CACb;UACA;GAEd,IAAM,IAAU,EAAI,MAAM,0BAA0B;AACpD,UAAO,IAAU,EAAQ,KAAK;;;CAWlC,aAAoB,GAA0B;AAC5C,SAAO,QAAQ,QAAQ,KAAA,EAAU;;CAGnC,WAAqB,GAAsB;EACzC,IAAM,IAAM,iBAAiB;AAC7B,SAAO,OAAO,gBAAgB,QAAQ,EAAI;;CAG5C,WAAqB,GAAmB,GAAiB;EACvD,IAAM,IAAM,iBAAiB;AAC7B,SAAO,gBAAgB,QAAQ,GAAK,EAAO;;CAM7C,YAAY;;ACrHd,MAAaA,iBAA6D;CACxE,SAAW;EACT,MAAM;EACN,MAAM;EACP;CACD,UAAY;EACV,MAAM;EACN,MAAM;EACP;CACF;ACeD,SAAgB,2BAA2B,GAAiI;CAC1K,IAAM,IAAY;AAElB,QADA,EAAU,WAAW,aAAa,YAC3B;;AA+BT,IAAsB,iBAAtB,MAA6E;AAyC7E,SAAgB,sBAAyB,GAAqE;AAE5G,QAAO"}
|
|
@@ -21,7 +21,7 @@ export declare function createFlowNodePluginConfig(config: Omit<FlowNodePluginCo
|
|
|
21
21
|
* // ...其他插件信息
|
|
22
22
|
* }
|
|
23
23
|
*
|
|
24
|
-
* async onExecute(flow, flowData
|
|
24
|
+
* async onExecute(ctx, flow, flowData) {
|
|
25
25
|
* const { quality } = flowData.nodeData
|
|
26
26
|
* // 压缩逻辑
|
|
27
27
|
* }
|
|
@@ -37,11 +37,11 @@ export declare function createFlowNodePluginConfig(config: Omit<FlowNodePluginCo
|
|
|
37
37
|
export declare abstract class FlowNodePlugin<T = any> implements IFlowNodeActions<T> {
|
|
38
38
|
/**
|
|
39
39
|
* 执行节点核心逻辑
|
|
40
|
+
* @param ctx 流程上下文
|
|
40
41
|
* @param flow 流程项
|
|
41
42
|
* @param flowData 流程节点数据
|
|
42
|
-
* @param data 流程上下文
|
|
43
43
|
*/
|
|
44
|
-
abstract onExecute(flow: IFlowItem, flowData: IFlowNode<T
|
|
44
|
+
abstract onExecute(ctx: IFlowContext, flow: IFlowItem, flowData: IFlowNode<T>): Promise<void>;
|
|
45
45
|
/**
|
|
46
46
|
* 保存数据后的钩子(可选)
|
|
47
47
|
* @param flow 流程项
|
|
@@ -62,7 +62,7 @@ export declare abstract class FlowNodePlugin<T = any> implements IFlowNodeAction
|
|
|
62
62
|
* @example
|
|
63
63
|
* // 方式1: 函数式配置(保持兼容)
|
|
64
64
|
* const actions = createFlowNodeActions({
|
|
65
|
-
* onExecute: async (flow, flowData
|
|
65
|
+
* onExecute: async (ctx, flow, flowData) => {
|
|
66
66
|
* // 逻辑
|
|
67
67
|
* }
|
|
68
68
|
* })
|