vue2-client 1.22.3 → 1.22.4

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.
Files changed (88) hide show
  1. package/.env.his +19 -19
  2. package/.idea/.name +1 -0
  3. package/.idea/MarsCodeWorkspaceAppSettings.xml +8 -0
  4. package/.idea/deployment.xml +14 -0
  5. package/.idea/gradle.xml +7 -0
  6. package/.idea/inspectionProfiles/Project_Default.xml +6 -0
  7. package/.idea/libraries/contour_plot.xml +9 -0
  8. package/.idea/material_theme_project_new.xml +18 -0
  9. package/.idea/misc.xml +87 -5
  10. package/package.json +1 -1
  11. package/src/base-client/components/common/HIS/HForm/HForm.vue +1186 -1186
  12. package/src/base-client/components/common/XMarkdownViewer/demo.vue +102 -102
  13. package/src/base-client/components/his/HAi/HAi.vue +1177 -1177
  14. package/src/base-client/components/his/XTransfer/index.md +327 -327
  15. package/src/base-client/plugins/GetLoginInfoService.js +4 -4
  16. package/src/utils/login.js +11 -11
  17. package/.history/.eslintrc_20260521171150.js +0 -74
  18. package/.history/.eslintrc_20260521171213.js +0 -74
  19. package/.history/src/base-client/components/common/HIS/HAddNativeForm/HAddNativeForm_20260601154443.vue +0 -726
  20. package/.history/src/base-client/components/common/HIS/HAddNativeForm/HAddNativeForm_20260601154700.vue +0 -478
  21. package/.history/src/base-client/components/common/HIS/HButtons/HButtons_20260512175435.vue +0 -706
  22. package/.history/src/base-client/components/common/HIS/HButtons/HButtons_20260512175450.vue +0 -694
  23. package/.history/src/base-client/components/common/HIS/HButtons/HButtons_20260611152602.vue +0 -755
  24. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260513145941.vue +0 -524
  25. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260513153133.vue +0 -731
  26. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260513160316.vue +0 -525
  27. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260601144150.vue +0 -1046
  28. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260310142713.vue +0 -512
  29. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260310145118.vue +0 -511
  30. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260311094834.vue +0 -696
  31. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260320143028.vue +0 -693
  32. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260409101450.vue +0 -677
  33. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260508164645.vue +0 -758
  34. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260508164714.vue +0 -693
  35. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260508171651.vue +0 -716
  36. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260509133717.vue +0 -695
  37. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260509171115.vue +0 -664
  38. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513140637.vue +0 -1455
  39. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513140935.vue +0 -1441
  40. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513150818.vue +0 -1441
  41. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513153119.vue +0 -1442
  42. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513153126.vue +0 -1486
  43. package/.history/src/base-client/components/common/XForm/XFormItem_20260513140854.vue +0 -1607
  44. package/.history/src/base-client/components/common/XMarkdownViewer/XMarkdownViewer_20260519140403.vue +0 -643
  45. package/.history/src/base-client/components/common/XMarkdownViewer/XMarkdownViewer_20260519140829.vue +0 -628
  46. package/.history/src/base-client/components/common/XMarkdownViewer/demo_20260519142824.vue +0 -104
  47. package/.history/src/base-client/components/common/XMarkdownViewer/demo_20260519143155.vue +0 -102
  48. package/.history/src/base-client/components/common/XReportGrid/XReport_20260309171231.vue +0 -1241
  49. package/.history/src/base-client/components/common/XReportGrid/XReport_20260309171441.vue +0 -1223
  50. package/.history/src/base-client/components/his/HAi/HAi_20260612174826.vue +0 -472
  51. package/.history/src/base-client/components/his/HAi/HAi_20260612175839.vue +0 -538
  52. package/.history/src/base-client/components/his/HAi/HAi_20260615103331.vue +0 -650
  53. package/.history/src/base-client/components/his/XHDescriptions/XHDescriptions_20260424134504.vue +0 -1469
  54. package/.history/src/base-client/components/his/XSidebar/XSidebar_20260610171133.vue +0 -788
  55. package/.history/src/base-client/components/his/XSidebar/XSidebar_20260610171151.vue +0 -780
  56. package/.history/src/base-client/components/his/XTransfer/XTransfer_20260511170841.vue +0 -585
  57. package/.history/src/base-client/components/his/XTransfer/XTransfer_20260511171138.vue +0 -787
  58. package/.history/src/base-client/components/his/XTransfer/XTransfer_20260512141830.vue +0 -739
  59. package/.history/src/components/STable/index_20260409155138.js +0 -806
  60. package/.history/src/components/STable/index_20260409155218.js +0 -814
  61. package/.history/src/expression/core/Expression_20260305164427.js +0 -1371
  62. package/.history/src/expression/core/Expression_20260305170258.js +0 -1358
  63. package/.history/src/expression/core/Program_20260305111830.js +0 -944
  64. package/.history/src/expression/core/Program_20260305112041.js +0 -931
  65. package/.history/src/logic/LogicRunner_20260304154306.js +0 -170
  66. package/.history/src/logic/LogicRunner_20260304155553.js +0 -112
  67. package/.history/src/logic/LogicRunner_20260305105834.js +0 -112
  68. package/.history/src/logic/LogicRunner_20260305112718.js +0 -129
  69. package/.history/src/logic/LogicRunner_20260305182436.js +0 -133
  70. package/.history/src/logic/LogicRunner_20260306151301.js +0 -213
  71. package/.history/src/logic/LogicRunner_20260306152419.js +0 -213
  72. package/.history/src/logic/plugins/common/DateTools_20260305154159.js +0 -61
  73. package/.history/src/logic/plugins/common/DateTools_20260305154217.js +0 -44
  74. package/.history/src/logic/plugins/common/DateTools_20260305161014.js +0 -44
  75. package/.history/src/logic/plugins/common/HttpTools_20260305164352.js +0 -80
  76. package/.history/src/logic/plugins/common/HttpTools_20260305170258.js +0 -75
  77. package/.history/src/logic/plugins/common/HttpTools_20260305171634.js +0 -75
  78. package/.history/src/logic/plugins/common/HttpTools_20260306152419.js +0 -72
  79. package/.history/src/services/api/restTools_20260427142149.js +0 -245
  80. package/.history/src/services/api/restTools_20260427142853.js +0 -230
  81. package/.history/src/services/api/restTools_20260519135558.js +0 -230
  82. package/.history/src/services/api/restTools_20260519140825.js +0 -230
  83. package/.history/src/services/api/restTools_20260519151223.js +0 -230
  84. package/.history/src/utils/indexedDB_20260306150918.js +0 -593
  85. package/.history/src/utils/indexedDB_20260306151301.js +0 -586
  86. package/.idea/codeStyles/Project.xml +0 -62
  87. package/.idea/codeStyles/codeStyleConfig.xml +0 -5
  88. package/preview-input-box.html +0 -180
@@ -1,170 +0,0 @@
1
- import ServiceException from '../expression/exception/ServiceException'
2
- import LogicConsole from '../expression/instances/LogicConsole'
3
- import ExpressionRunner from '../expression/ExpressionRunner'
4
- import { getLogicConfigByNameAsync } from '@vue2-client/services/api/common'
5
- import * as Plugins from './plugins/index'
6
- import Expression from '../expression/core/Expression'
7
-
8
- export default class LogicRunner {
9
- static logicConsoleInstance = new LogicConsole()
10
-
11
- // 存储正在运行的 Logic 任务,key 为 logicName,value 为 { promise, abortController }
12
- static runningTasks = new Map()
13
-
14
- // 缓存 Logic 配置请求,key 为 logicName,value 为 Promise
15
- static logicConfigCache = new Map()
16
-
17
- /**
18
- * 是否存在指定名称的Logic资源
19
- *
20
- * @param logicName Logic名称
21
- * @return 是否存在
22
- */
23
- static async has (logicName) {
24
- const result = await LogicRunner.getLogic(logicName, false)
25
- return result != null
26
- }
27
-
28
- /**
29
- * 执行Logic
30
- *
31
- * @param logicName Logic名称
32
- * @param param 参数
33
- * @param mode 运行模式:undefined-普通模式,'ignore'-忽略重复,'cancel'-取消前一个
34
- * @return 执行结果
35
- */
36
- static async run (logicName, param, mode) {
37
- const taskKey = logicName
38
-
39
- // 模式1: ignore - 如果已存在运行中的任务,直接忽略当前调用
40
- if (mode === 'ignore') {
41
- if (LogicRunner.runningTasks.has(taskKey)) {
42
- console.log(`[LogicRunner] ${logicName} 已在运行中,忽略本次调用`)
43
- return null
44
- }
45
- }
46
-
47
- // 模式2: cancel - 如果已存在运行中的任务,中止之前的任务
48
- if (mode === 'cancel') {
49
- const existingTask = LogicRunner.runningTasks.get(taskKey)
50
- if (existingTask && existingTask.abortController) {
51
- console.log(`[LogicRunner] 取消 ${logicName} 的前一次运行`)
52
- existingTask.abortController.abort()
53
- }
54
- }
55
-
56
- // 创建 AbortController 用于支持取消功能
57
- const abortController = new AbortController()
58
- const taskPromise = LogicRunner.executeLogic(logicName, param, abortController)
59
-
60
- // 存储任务信息
61
- LogicRunner.runningTasks.set(taskKey, { promise: taskPromise, abortController })
62
-
63
- try {
64
- const result = await taskPromise
65
- return result
66
- } finally {
67
- // 任务完成后移除(如果是 cancel 模式,可能已经被新的任务覆盖)
68
- const currentTask = LogicRunner.runningTasks.get(taskKey)
69
- if (currentTask && currentTask.promise === taskPromise) {
70
- LogicRunner.runningTasks.delete(taskKey)
71
- }
72
- }
73
- }
74
-
75
- /**
76
- * 实际执行 Logic 的内部方法
77
- */
78
- static async executeLogic (logicName, param, abortController) {
79
- // 获取Logic资源(带缓存,避免重复请求)
80
- const cachedConfig = LogicRunner.logicConfigCache.get(logicName)
81
- let result
82
-
83
- if (cachedConfig) {
84
- // 使用缓存的配置
85
- result = await cachedConfig
86
- } else {
87
- // 发起新请求并缓存
88
- const configPromise = LogicRunner.getLogic(logicName, false)
89
- LogicRunner.logicConfigCache.set(logicName, configPromise)
90
- result = await configPromise
91
- }
92
-
93
- if (!result || !result.source) {
94
- throw new ServiceException('Logic资源' + logicName + '未找到', 400)
95
- }
96
- // 预处理 source:移除换行符,将换行替换为分号,避免解析器报错
97
- const source = result.source.replace(/[\r\n]+/g, ';')
98
- const paramStr = Expression.toJSONString(param)
99
- const logicLog = LogicConsole.createLogger('logic.' + logicName)
100
- logicLog.info(`执行Logic[${logicName}],params: ${paramStr}`)
101
- // 附加用户注册的对象到业务逻辑中
102
- const plugins = {}
103
- plugins.data = param
104
- plugins.log = logicLog
105
- plugins.ENV = result.$globalProp
106
- plugins.logic = this
107
- // 注入 abortSignal 到 plugins,用于支持取消操作
108
- plugins.abortSignal = abortController.signal
109
- Object.assign(plugins, Plugins.default)
110
-
111
- // 使用 Promise 包装执行,以便监听 abort 信号
112
- return new Promise((resolve, reject) => {
113
- // 监听 abort 信号
114
- const abortHandler = () => {
115
- const error = new Error(`Logic[${logicName}] 被取消`)
116
- error.name = 'AbortError'
117
- reject(error)
118
- }
119
-
120
- if (abortController.signal.aborted) {
121
- abortHandler()
122
- return
123
- }
124
-
125
- abortController.signal.addEventListener('abort', abortHandler)
126
-
127
- // 执行表达式
128
- LogicRunner.runExpression(source, plugins)
129
- .then(result => {
130
- abortController.signal.removeEventListener('abort', abortHandler)
131
- resolve(result)
132
- })
133
- .catch(error => {
134
- abortController.signal.removeEventListener('abort', abortHandler)
135
- // 如果是 abort 错误,不再重复抛出(避免 console 显示 unhandled promise rejection)
136
- if (error.name === 'AbortError') {
137
- return
138
- }
139
- reject(error)
140
- })
141
- })
142
- }
143
-
144
- /**
145
- * 执行原生表达式
146
- *
147
- * @param source 表达式内容
148
- * @param params 参数
149
- * @return 执行结果
150
- */
151
- static async runExpression (source, params) {
152
- return await ExpressionRunner.run(source, params)
153
- }
154
-
155
- static async getLogic (logicName, isDev) {
156
- return await getLogicConfigByNameAsync(logicName, undefined, isDev)
157
- }
158
-
159
- /**
160
- * 清除指定 Logic 的缓存
161
- */
162
- static clearCache (logicName) {
163
- if (logicName) {
164
- LogicRunner.logicConfigCache.delete(logicName)
165
- } else {
166
- // 清除所有缓存
167
- LogicRunner.logicConfigCache.clear()
168
- }
169
- }
170
- }
@@ -1,112 +0,0 @@
1
- import ServiceException from '../expression/exception/ServiceException'
2
- import LogicConsole from '../expression/instances/LogicConsole'
3
- import ExpressionRunner from '../expression/ExpressionRunner'
4
- import { getLogicConfigByNameAsync } from '@vue2-client/services/api/common'
5
- import * as Plugins from './plugins/index'
6
- import Expression from '../expression/core/Expression'
7
-
8
- export default class LogicRunner {
9
- static logicConsoleInstance = new LogicConsole()
10
-
11
- // 存储正在运行的 Logic 任务,key 为 logicName,value 为 { promise, abortController }
12
- static runningTasks = new Map()
13
-
14
- /**
15
- * 是否存在指定名称的Logic资源
16
- *
17
- * @param logicName Logic名称
18
- * @return 是否存在
19
- */
20
- static async has (logicName) {
21
- const result = await LogicRunner.getLogic(logicName, false)
22
- return result != null
23
- }
24
-
25
- /**
26
- * 执行Logic
27
- *
28
- * @param logicName Logic名称
29
- * @param param 参数
30
- * @param mode 运行模式:undefined-普通模式,'ignore'-忽略重复,'cancel'-取消前一个
31
- * @return 执行结果
32
- */
33
- static async run (logicName, param, mode) {
34
- const taskKey = logicName
35
-
36
- // 模式1: ignore - 如果已存在运行中的任务,直接忽略当前调用
37
- if (mode === 'ignore') {
38
- if (LogicRunner.runningTasks.has(taskKey)) {
39
- console.log(`[LogicRunner] ${logicName} 已在运行中,忽略本次调用`)
40
- return null
41
- }
42
- }
43
-
44
- // 模式2: cancel - 如果已存在运行中的任务,中止之前的任务
45
- if (mode === 'cancel') {
46
- const existingTask = LogicRunner.runningTasks.get(taskKey)
47
- if (existingTask && existingTask.abortController) {
48
- console.log(`[LogicRunner] 取消 ${logicName} 的前一次运行`)
49
- existingTask.abortController.abort()
50
- }
51
- }
52
-
53
- // 创建 AbortController 用于支持取消功能
54
- const abortController = new AbortController()
55
- const taskPromise = LogicRunner.executeLogic(logicName, param, abortController)
56
-
57
- // 存储任务信息
58
- LogicRunner.runningTasks.set(taskKey, { promise: taskPromise, abortController })
59
-
60
- try {
61
- const result = await taskPromise
62
- return result
63
- } finally {
64
- // 任务完成后移除(如果是 cancel 模式,可能已经被新的任务覆盖)
65
- const currentTask = LogicRunner.runningTasks.get(taskKey)
66
- if (currentTask && currentTask.promise === taskPromise) {
67
- LogicRunner.runningTasks.delete(taskKey)
68
- }
69
- }
70
- }
71
-
72
- /**
73
- * 实际执行 Logic 的内部方法
74
- */
75
- static async executeLogic (logicName, param, abortController) {
76
- // 获取Logic资源(传 shouldParseConfig: false,不触发服务端解析)
77
- const result = await LogicRunner.getLogic(logicName, false)
78
- if (!result || !result.source) {
79
- throw new ServiceException('Logic资源' + logicName + '未找到', 400)
80
- }
81
- // 预处理 source:移除换行符,将换行替换为分号,避免解析器报错
82
- const source = result.source.replace(/[\r\n]+/g, ';')
83
- const paramStr = Expression.toJSONString(param)
84
- const logicLog = LogicConsole.createLogger('logic.' + logicName)
85
- logicLog.info(`执行Logic[${logicName}],params: ${paramStr}`)
86
- // 附加用户注册的对象到业务逻辑中
87
- const plugins = {}
88
- plugins.data = param
89
- plugins.log = logicLog
90
- plugins.ENV = result.$globalProp
91
- plugins.logic = this
92
- // 注入 abortSignal 到 plugins,用于支持取消操作
93
- plugins.abortSignal = abortController.signal
94
- Object.assign(plugins, Plugins.default)
95
- return LogicRunner.runExpression(source, plugins)
96
- }
97
-
98
- /**
99
- * 执行原生表达式
100
- *
101
- * @param source 表达式内容
102
- * @param params 参数
103
- * @return 执行结果
104
- */
105
- static async runExpression (source, params) {
106
- return await ExpressionRunner.run(source, params)
107
- }
108
-
109
- static async getLogic (logicName, isDev) {
110
- return await getLogicConfigByNameAsync(logicName, undefined, isDev)
111
- }
112
- }
@@ -1,112 +0,0 @@
1
- import ServiceException from '../expression/exception/ServiceException'
2
- import LogicConsole from '../expression/instances/LogicConsole'
3
- import ExpressionRunner from '../expression/ExpressionRunner'
4
- import { getLogicConfigByNameAsync } from '@vue2-client/services/api/common'
5
- import * as Plugins from './plugins/index'
6
- import Expression from '../expression/core/Expression'
7
-
8
- export default class LogicRunner {
9
- static logicConsoleInstance = new LogicConsole()
10
-
11
- // 存储正在运行的 Logic 任务,key 为 logicName,value 为 { promise, abortController }
12
- static runningTasks = new Map()
13
-
14
- /**
15
- * 是否存在指定名称的Logic资源
16
- *
17
- * @param logicName Logic名称
18
- * @return 是否存在
19
- */
20
- static async has (logicName) {
21
- const result = await LogicRunner.getLogic(logicName, false)
22
- return result != null
23
- }
24
-
25
- /**
26
- * 执行Logic
27
- *
28
- * @param logicName Logic名称
29
- * @param param 参数
30
- * @param mode 运行模式:undefined-普通模式,'ignore'-忽略重复,'cancel'-取消前一个
31
- * @return 执行结果
32
- */
33
- static async run (logicName, param, mode) {
34
- const taskKey = logicName
35
-
36
- // 模式1: ignore - 如果已存在运行中的任务,直接忽略当前调用
37
- if (mode === 'ignore') {
38
- if (LogicRunner.runningTasks.has(taskKey)) {
39
- console.log(`[LogicRunner] ${logicName} 已在运行中,忽略本次调用`)
40
- return null
41
- }
42
- }
43
-
44
- // 模式2: cancel - 如果已存在运行中的任务,中止之前的任务
45
- if (mode === 'cancel') {
46
- const existingTask = LogicRunner.runningTasks.get(taskKey)
47
- if (existingTask && existingTask.abortController) {
48
- console.log(`[LogicRunner] 取消 ${logicName} 的前一次运行`)
49
- existingTask.abortController.abort()
50
- }
51
- }
52
-
53
- // 创建 AbortController 用于支持取消功能
54
- const abortController = new AbortController()
55
- const taskPromise = LogicRunner.executeLogic(logicName, param, abortController)
56
-
57
- // 存储任务信息
58
- LogicRunner.runningTasks.set(taskKey, { promise: taskPromise, abortController })
59
-
60
- try {
61
- const result = await taskPromise
62
- return result
63
- } finally {
64
- // 任务完成后移除(如果是 cancel 模式,可能已经被新的任务覆盖)
65
- const currentTask = LogicRunner.runningTasks.get(taskKey)
66
- if (currentTask && currentTask.promise === taskPromise) {
67
- LogicRunner.runningTasks.delete(taskKey)
68
- }
69
- }
70
- }
71
-
72
- /**
73
- * 实际执行 Logic 的内部方法
74
- */
75
- static async executeLogic (logicName, param, abortController) {
76
- // 获取Logic资源(传 shouldParseConfig: false,不触发服务端解析)
77
- const result = await LogicRunner.getLogic(logicName, false)
78
- if (!result || !result.source) {
79
- throw new ServiceException('Logic资源' + logicName + '未找到', 400)
80
- }
81
- // 预处理 source:移除换行符,将换行替换为分号,避免解析器报错
82
- const source = result.source.replace(/[\r\n]+/g, ';')
83
- const paramStr = Expression.toJSONString(param)
84
- const logicLog = LogicConsole.createLogger('logic.' + logicName)
85
- logicLog.info(`执行Logic[${logicName}],params: ${paramStr}`)
86
- // 附加用户注册的对象到业务逻辑中
87
- const plugins = {}
88
- plugins.data = param
89
- plugins.log = logicLog
90
- plugins.ENV = result.$globalProp
91
- plugins.logic = this
92
- // 注入 abortSignal 到 plugins,用于支持取消操作
93
- plugins.abortSignal = abortController.signal
94
- Object.assign(plugins, Plugins.default)
95
- return LogicRunner.runExpression(source, plugins)
96
- }
97
-
98
- /**
99
- * 执行原生表达式
100
- *
101
- * @param source 表达式内容
102
- * @param params 参数
103
- * @return 执行结果
104
- */
105
- static async runExpression (source, params) {
106
- return await ExpressionRunner.run(source, params)
107
- }
108
-
109
- static async getLogic (logicName, isDev) {
110
- return await getLogicConfigByNameAsync(logicName, undefined, isDev)
111
- }
112
- }
@@ -1,129 +0,0 @@
1
- import ServiceException from '../expression/exception/ServiceException'
2
- import LogicConsole from '../expression/instances/LogicConsole'
3
- import ExpressionRunner from '../expression/ExpressionRunner'
4
- import { getLogicConfigByNameAsync } from '@vue2-client/services/api/common'
5
- import * as Plugins from './plugins/index'
6
- import Expression from '../expression/core/Expression'
7
-
8
- export default class LogicRunner {
9
- static logicConsoleInstance = new LogicConsole()
10
-
11
- // 存储正在运行的 Logic 任务,key 为 logicName,value 为 { promise, abortController, status }
12
- // status: 'running' - 运行中, 'completed' - 已完成(用于ignore模式判断)
13
- static runningTasks = new Map()
14
-
15
- // 任务完成后保持"已完成"状态的时间(毫秒),之后自动清理
16
- static COMPLETED_STATUS_TTL = 3000
17
-
18
- /**
19
- * 是否存在指定名称的Logic资源
20
- *
21
- * @param logicName Logic名称
22
- * @return 是否存在
23
- */
24
- static async has (logicName) {
25
- const result = await LogicRunner.getLogic(logicName, false)
26
- return result != null
27
- }
28
-
29
- /**
30
- * 执行Logic
31
- *
32
- * @param logicName Logic名称
33
- * @param param 参数
34
- * @param mode 运行模式:undefined-普通模式,'ignore'-忽略重复,'cancel'-取消前一个
35
- * @return 执行结果
36
- */
37
- static async run (logicName, param, mode) {
38
- const taskKey = logicName
39
-
40
- // 检查已存在的任务
41
- const existingTask = LogicRunner.runningTasks.get(taskKey)
42
-
43
- // 模式1: ignore - 如果已存在运行中的任务,直接忽略当前调用
44
- if (mode === 'ignore') {
45
- // 如果任务正在运行中,忽略本次调用
46
- if (existingTask && existingTask.status === 'running') {
47
- console.log(`[LogicRunner] ${logicName} 已在运行中,忽略本次调用`)
48
- return null
49
- }
50
- }
51
-
52
- // 模式2: cancel - 如果已存在运行中的任务,中止之前的任务
53
- if (mode === 'cancel') {
54
- if (existingTask && existingTask.status === 'running') {
55
- console.log(`[LogicRunner] 取消 ${logicName} 的前一次运行`)
56
- if (existingTask.abortController) {
57
- existingTask.abortController.abort()
58
- }
59
- }
60
- }
61
-
62
- // 创建 AbortController 用于支持取消功能
63
- const abortController = new AbortController()
64
- const taskPromise = LogicRunner.executeLogic(logicName, param, abortController)
65
-
66
- // 存储任务信息,设置状态为运行中
67
- LogicRunner.runningTasks.set(taskKey, { promise: taskPromise, abortController, status: 'running' })
68
-
69
- try {
70
- const result = await taskPromise
71
- return result
72
- } finally {
73
- // 任务完成后更新状态为已完成,而不是直接删除
74
- const currentTask = LogicRunner.runningTasks.get(taskKey)
75
- if (currentTask && currentTask.promise === taskPromise) {
76
- currentTask.status = 'completed'
77
-
78
- // 延迟删除任务,让 ignore 模式可以检测到"刚完成"的状态
79
- setTimeout(() => {
80
- const task = LogicRunner.runningTasks.get(taskKey)
81
- if (task && task.status === 'completed') {
82
- LogicRunner.runningTasks.delete(taskKey)
83
- }
84
- }, LogicRunner.COMPLETED_STATUS_TTL)
85
- }
86
- }
87
- }
88
-
89
- /**
90
- * 实际执行 Logic 的内部方法
91
- */
92
- static async executeLogic (logicName, param, abortController) {
93
- // 获取Logic资源(传 shouldParseConfig: false,不触发服务端解析)
94
- const result = await LogicRunner.getLogic(logicName, false)
95
- if (!result || !result.source) {
96
- throw new ServiceException('Logic资源' + logicName + '未找到', 400)
97
- }
98
- // 预处理 source:移除换行符,将换行替换为分号,避免解析器报错
99
- const source = result.source.replace(/[\r\n]+/g, ';')
100
- const paramStr = Expression.toJSONString(param)
101
- const logicLog = LogicConsole.createLogger('logic.' + logicName)
102
- logicLog.info(`执行Logic[${logicName}],params: ${paramStr}`)
103
- // 附加用户注册的对象到业务逻辑中
104
- const plugins = {}
105
- plugins.data = param
106
- plugins.log = logicLog
107
- plugins.ENV = result.$globalProp
108
- plugins.logic = this
109
- // 注入 abortSignal 到 plugins,用于支持取消操作
110
- plugins.abortSignal = abortController.signal
111
- Object.assign(plugins, Plugins.default)
112
- return LogicRunner.runExpression(source, plugins)
113
- }
114
-
115
- /**
116
- * 执行原生表达式
117
- *
118
- * @param source 表达式内容
119
- * @param params 参数
120
- * @return 执行结果
121
- */
122
- static async runExpression (source, params) {
123
- return await ExpressionRunner.run(source, params)
124
- }
125
-
126
- static async getLogic (logicName, isDev) {
127
- return await getLogicConfigByNameAsync(logicName, undefined, isDev)
128
- }
129
- }
@@ -1,133 +0,0 @@
1
- import ServiceException from '../expression/exception/ServiceException'
2
- import LogicConsole from '../expression/instances/LogicConsole'
3
- import ExpressionRunner from '../expression/ExpressionRunner'
4
- import { getLogicConfigByNameAsync } from '@vue2-client/services/api/common'
5
- import * as Plugins from './plugins/index'
6
- import Expression from '../expression/core/Expression'
7
-
8
- export default class LogicRunner {
9
- static logicConsoleInstance = new LogicConsole()
10
-
11
- // 存储正在运行的 Logic 任务,key 为 logicName,value 为 { promise, abortController, status }
12
- // status: 'running' - 运行中, 'completed' - 已完成(用于ignore模式判断)
13
- static runningTasks = new Map()
14
-
15
- // 任务完成后保持"已完成"状态的时间(毫秒),之后自动清理
16
- static COMPLETED_STATUS_TTL = 3000
17
-
18
- /**
19
- * 是否存在指定名称的Logic资源
20
- *
21
- * @param logicName Logic名称
22
- * @return 是否存在
23
- */
24
- static async has (logicName) {
25
- const result = await LogicRunner.getLogic(logicName, false)
26
- return result != null
27
- }
28
-
29
- /**
30
- * 执行Logic
31
- *
32
- * @param logicName Logic名称
33
- * @param param 参数
34
- * @param mode 运行模式:undefined-普通模式,'ignore'-忽略重复,'cancel'-取消前一个
35
- * @return 执行结果
36
- */
37
- static async run (logicName, param, mode) {
38
- const taskKey = logicName
39
-
40
- // 检查已存在的任务
41
- const existingTask = LogicRunner.runningTasks.get(taskKey)
42
-
43
- // 模式1: ignore - 如果已存在运行中的任务,直接忽略当前调用
44
- if (mode === 'ignore') {
45
- // 如果任务正在运行中,忽略本次调用
46
- if (existingTask && existingTask.status === 'running') {
47
- console.log(`[LogicRunner] ${logicName} 已在运行中,忽略本次调用`)
48
- return null
49
- }
50
- }
51
-
52
- // 模式2: cancel - 如果已存在运行中的任务,中止之前的任务
53
- if (mode === 'cancel') {
54
- if (existingTask && existingTask.status === 'running') {
55
- console.log(`[LogicRunner] 取消 ${logicName} 的前一次运行`)
56
- if (existingTask.abortController) {
57
- existingTask.abortController.abort()
58
- }
59
- }
60
- }
61
-
62
- // 创建 AbortController 用于支持取消功能
63
- const abortController = new AbortController()
64
- const taskPromise = LogicRunner.executeLogic(logicName, param, abortController)
65
-
66
- // 存储任务信息,设置状态为运行中
67
- LogicRunner.runningTasks.set(taskKey, { promise: taskPromise, abortController, status: 'running' })
68
-
69
- try {
70
- const result = await taskPromise
71
- return result
72
- } finally {
73
- // 任务完成后更新状态为已完成,而不是直接删除
74
- const currentTask = LogicRunner.runningTasks.get(taskKey)
75
- if (currentTask && currentTask.promise === taskPromise) {
76
- currentTask.status = 'completed'
77
-
78
- // 延迟删除任务,让 ignore 模式可以检测到"刚完成"的状态
79
- setTimeout(() => {
80
- const task = LogicRunner.runningTasks.get(taskKey)
81
- if (task && task.status === 'completed') {
82
- LogicRunner.runningTasks.delete(taskKey)
83
- }
84
- }, LogicRunner.COMPLETED_STATUS_TTL)
85
- }
86
- }
87
- }
88
-
89
- /**
90
- * 实际执行 Logic 的内部方法
91
- */
92
- static async executeLogic (logicName, param, abortController) {
93
- // 获取Logic资源(传 shouldParseConfig: false,不触发服务端解析)
94
- const result = await LogicRunner.getLogic(logicName, false)
95
- if (!result || !result.source) {
96
- throw new ServiceException('Logic资源' + logicName + '未找到', 400)
97
- }
98
- // 预处理 source:移除换行符,将换行替换为分号,避免解析器报错
99
- const source = result.source.replace(/[\r\n]+/g, '')
100
- const paramStr = Expression.toJSONString(param)
101
- const logicLog = LogicConsole.createLogger('logic.' + logicName)
102
- logicLog.info(`执行Logic[${logicName}],params: ${paramStr}`)
103
- // 附加用户注册的对象到业务逻辑中
104
- const plugins = {}
105
- plugins.data = param
106
- plugins.log = logicLog
107
- plugins.ENV = result.$globalProp
108
- plugins.logic = this
109
-
110
- // 注入 abortSignal 到 plugins,用于支持取消操作
111
- console.log('[LogicRunner.executeLogic] 设置 abortSignal:', abortController.signal)
112
- plugins.abortSignal = abortController.signal
113
-
114
- Object.assign(plugins, Plugins.default)
115
-
116
- return await LogicRunner.runExpression(source, plugins)
117
- }
118
-
119
- /**
120
- * 执行原生表达式
121
- *
122
- * @param source 表达式内容
123
- * @param params 参数
124
- * @return 执行结果
125
- */
126
- static async runExpression (source, params) {
127
- return await ExpressionRunner.run(source, params)
128
- }
129
-
130
- static async getLogic (logicName, isDev) {
131
- return await getLogicConfigByNameAsync(logicName, undefined, isDev)
132
- }
133
- }