adtec-core-package 1.2.4 → 1.2.6

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 (190) hide show
  1. package/README.en.md +36 -36
  2. package/eslint.config.js +11 -21
  3. package/package.json +66 -64
  4. package/src/api/BasicApi.ts +26 -26
  5. package/src/api/DeptInfoApi.ts +19 -19
  6. package/src/api/DocumentApi.ts +27 -27
  7. package/src/api/EmployeeInfoApi.ts +17 -17
  8. package/src/api/SysDictCacheApi.ts +29 -29
  9. package/src/api/SysUserApi.ts +35 -35
  10. package/src/api/framework.ts +12 -12
  11. package/src/api/workflow/workflow.ts +31 -31
  12. package/src/api/workflow/workflowInstApi.ts +72 -72
  13. package/src/assets/style/ant.scss +19 -19
  14. package/src/assets/style/index.less +180 -180
  15. package/src/components/ElFlex/ElFlex.vue +297 -297
  16. package/src/components/ElTotalTools.vue +70 -70
  17. package/src/components/OperationAuth/operationAuth.vue +26 -26
  18. package/src/components/RichTextEditor/RichTextEditor.vue +144 -144
  19. package/src/components/Scrollbars/ElScrollbars.vue +21 -21
  20. package/src/components/Search/ElIconSearch.vue +267 -267
  21. package/src/components/Search/ElSearch.vue +154 -154
  22. package/src/components/SelectInDicators/SelectInDicators.vue +225 -225
  23. package/src/components/SelectInDicators/api/DataIndicatorsApi.ts +28 -28
  24. package/src/components/SelectInDicators/interface/IComIndex.ts +26 -26
  25. package/src/components/SelectInDicators/interface/IComIndexAttri.ts +18 -18
  26. package/src/components/Table/ElTableColumnDynamic.vue +25 -25
  27. package/src/components/Table/ElTableColumnEdit.vue +264 -263
  28. package/src/components/Table/ElTableTool.ts +37 -37
  29. package/src/components/Title/ElTitle.vue +53 -53
  30. package/src/components/autoToolTip/ElAutoToolTip.vue +62 -62
  31. package/src/components/baseEcharts/index.vue +48 -48
  32. package/src/components/bpmntree/api/modules/role.ts +31 -31
  33. package/src/components/bpmntree/api/modules/user.ts +17 -17
  34. package/src/components/bpmntree/components/AdvancedFilter/Operator.vue +112 -112
  35. package/src/components/bpmntree/components/AdvancedFilter/Trigger.vue +23 -23
  36. package/src/components/bpmntree/components/AdvancedFilter/index.vue +230 -230
  37. package/src/components/bpmntree/components/AdvancedFilter/type.ts +20 -20
  38. package/src/components/bpmntree/components/FlowIcon/index.scss +7 -7
  39. package/src/components/bpmntree/components/FlowIcon/index.tsx +68 -68
  40. package/src/components/bpmntree/components/Render/render.vue +90 -90
  41. package/src/components/bpmntree/components/Render/type.ts +12 -12
  42. package/src/components/bpmntree/components/RoleSelector/RolePicker.vue +264 -264
  43. package/src/components/bpmntree/components/RoleSelector/RoleTag.vue +48 -48
  44. package/src/components/bpmntree/components/RoleSelector/index.vue +113 -113
  45. package/src/components/bpmntree/components/UserSelector/UserTag.vue +73 -73
  46. package/src/components/bpmntree/components/UserSelector/index.vue +140 -140
  47. package/src/components/bpmntree/hooks/useDraggableScroll.ts +44 -44
  48. package/src/components/bpmntree/typings/index.d.ts +1 -1
  49. package/src/components/bpmntree/views/flowDesign/index.vue +652 -652
  50. package/src/components/bpmntree/views/flowDesign/nodes/Add.vue +184 -184
  51. package/src/components/bpmntree/views/flowDesign/nodes/ApprovalNode.vue +127 -127
  52. package/src/components/bpmntree/views/flowDesign/nodes/CcNode.vue +93 -93
  53. package/src/components/bpmntree/views/flowDesign/nodes/ConcurrentNode.vue +61 -61
  54. package/src/components/bpmntree/views/flowDesign/nodes/ConditionNode.vue +59 -59
  55. package/src/components/bpmntree/views/flowDesign/nodes/EndNode.vue +80 -80
  56. package/src/components/bpmntree/views/flowDesign/nodes/ExclusiveNode.vue +20 -20
  57. package/src/components/bpmntree/views/flowDesign/nodes/GatewayNode.vue +173 -173
  58. package/src/components/bpmntree/views/flowDesign/nodes/InclusiveNode.vue +20 -20
  59. package/src/components/bpmntree/views/flowDesign/nodes/JumpNode.vue +49 -49
  60. package/src/components/bpmntree/views/flowDesign/nodes/Node.vue +346 -346
  61. package/src/components/bpmntree/views/flowDesign/nodes/NotifyNode.vue +115 -115
  62. package/src/components/bpmntree/views/flowDesign/nodes/ParallelNode.vue +20 -20
  63. package/src/components/bpmntree/views/flowDesign/nodes/PopoverView.vue +78 -78
  64. package/src/components/bpmntree/views/flowDesign/nodes/StartNode.vue +84 -84
  65. package/src/components/bpmntree/views/flowDesign/nodes/TimerNode.vue +50 -50
  66. package/src/components/bpmntree/views/flowDesign/nodes/TreeNode.vue +45 -45
  67. package/src/components/bpmntree/views/flowDesign/nodes/type.ts +192 -192
  68. package/src/components/bpmntree/views/flowDesign/panels/ApprovalPanel.vue +516 -516
  69. package/src/components/bpmntree/views/flowDesign/panels/AssigneePanel.vue +120 -120
  70. package/src/components/bpmntree/views/flowDesign/panels/CcPanel.vue +99 -99
  71. package/src/components/bpmntree/views/flowDesign/panels/ConditionPanel.vue +41 -41
  72. package/src/components/bpmntree/views/flowDesign/panels/EndPanel.vue +18 -18
  73. package/src/components/bpmntree/views/flowDesign/panels/ExecutionListeners.vue +110 -110
  74. package/src/components/bpmntree/views/flowDesign/panels/JumpPanel.vue +32 -32
  75. package/src/components/bpmntree/views/flowDesign/panels/NotifyPanel.vue +101 -101
  76. package/src/components/bpmntree/views/flowDesign/panels/ParaPanel.vue +248 -248
  77. package/src/components/bpmntree/views/flowDesign/panels/StartPanel.vue +159 -159
  78. package/src/components/bpmntree/views/flowDesign/panels/TaskListeners.vue +110 -110
  79. package/src/components/bpmntree/views/flowDesign/panels/TimerPanel.vue +51 -51
  80. package/src/components/bpmntree/views/flowDesign/panels/index.vue +85 -85
  81. package/src/components/bpmntree/views/view.index.vue +291 -291
  82. package/src/components/business/comp.userForm.vue +292 -286
  83. package/src/components/business/userSelect.vue +413 -413
  84. package/src/components/icon/ElIconBtn.vue +210 -210
  85. package/src/components/upload/ElUploads.vue +285 -285
  86. package/src/components/upload/FileView.vue +159 -159
  87. package/src/components/upload/FileViewComponents.vue +56 -56
  88. package/src/components/workflow/TaskOperation.vue +212 -212
  89. package/src/components/workflow/WorkflowTodoDialog.vue +81 -81
  90. package/src/components/workflow/components/AddOrMinusMultiDialog.vue +159 -159
  91. package/src/components/workflow/components/CheckDialog.vue +315 -316
  92. package/src/components/workflow/components/ProcessDetailComp.vue +133 -133
  93. package/src/components/workflow/components/ProcessDetailDialog.vue +129 -129
  94. package/src/components/workflow/components/ProcessInstance.vue +117 -117
  95. package/src/components/workflow/components/ProcessInstanceStep.vue +226 -226
  96. package/src/components/workflow/components/SelectAssigneeDialog.vue +109 -109
  97. package/src/components/workflow/components/SelectReturnActivityDialog.vue +104 -104
  98. package/src/config/ElementPlusConfig.ts +95 -95
  99. package/src/config/VxeTableConfig.ts +35 -0
  100. package/src/css/elementUI/autocomplete.scss +89 -89
  101. package/src/css/elementUI/common/var.scss +1549 -1549
  102. package/src/css/elementUI/date-picker/picker.scss +219 -219
  103. package/src/css/elementUI/descriptions.scss +152 -152
  104. package/src/css/elementUI/drawer.scss +164 -164
  105. package/src/css/elementUI/table.scss +694 -694
  106. package/src/css/elementUI/tabs.scss +659 -659
  107. package/src/css/vxeTableUI/all.scss +7 -0
  108. package/src/css/vxeTableUI/base.scss +16 -0
  109. package/src/css/vxeTableUI/components/colgroup.scss +0 -0
  110. package/src/css/vxeTableUI/components/column.scss +0 -0
  111. package/src/css/vxeTableUI/components/grid.scss +83 -0
  112. package/src/css/vxeTableUI/components/icon.scss +205 -0
  113. package/src/css/vxeTableUI/components/old-icon.scss +715 -0
  114. package/src/css/vxeTableUI/components/table-module/all.scss +7 -0
  115. package/src/css/vxeTableUI/components/table-module/custom.scss +491 -0
  116. package/src/css/vxeTableUI/components/table-module/edit.scss +0 -0
  117. package/src/css/vxeTableUI/components/table-module/export.scss +130 -0
  118. package/src/css/vxeTableUI/components/table-module/filter.scss +128 -0
  119. package/src/css/vxeTableUI/components/table-module/keyboard.scss +0 -0
  120. package/src/css/vxeTableUI/components/table-module/menu.scss +86 -0
  121. package/src/css/vxeTableUI/components/table-module/validator.scss +0 -0
  122. package/src/css/vxeTableUI/components/table.scss +2242 -0
  123. package/src/css/vxeTableUI/components/toolbar.scss +100 -0
  124. package/src/css/vxeTableUI/components/ui.scss +0 -0
  125. package/src/css/vxeTableUI/components/v-x-e-table.scss +0 -0
  126. package/src/css/vxeTableUI/cssvar.scss +3 -0
  127. package/src/css/vxeTableUI/default.scss +3 -0
  128. package/src/css/vxeTableUI/helpers/baseMixin.scss +82 -0
  129. package/src/css/vxeTableUI/icon/iconfont.ttf +0 -0
  130. package/src/css/vxeTableUI/icon/iconfont.woff +0 -0
  131. package/src/css/vxeTableUI/icon/iconfont.woff2 +0 -0
  132. package/src/css/vxeTableUI/index.scss +4 -0
  133. package/src/css/vxeTableUI/modules.scss +5 -0
  134. package/src/css/vxeTableUI/theme/base.scss +89 -0
  135. package/src/css/vxeTableUI/theme/dark.scss +46 -0
  136. package/src/css/vxeTableUI/theme/light.scss +42 -0
  137. package/src/css/vxeTableUI/variable.scss +41 -0
  138. package/src/directives/vKeydown.ts +91 -91
  139. package/src/hooks/useDictHooks.ts +119 -119
  140. package/src/hooks/useEcharts.ts +58 -58
  141. package/src/hooks/useFileView.ts +34 -11
  142. package/src/hooks/useMessageHooks.ts +132 -132
  143. package/src/hooks/usePermissionToolHooks.ts +21 -21
  144. package/src/hooks/useResetRefHooks.ts +18 -18
  145. package/src/hooks/userWorkflowHooks.ts +92 -92
  146. package/src/interface/BaseEntity.ts +30 -30
  147. package/src/interface/IMdmDept.ts +84 -84
  148. package/src/interface/IMdmEmployee.ts +134 -134
  149. package/src/interface/IMdmEmployeeQuery.ts +20 -19
  150. package/src/interface/IMdmOrg.ts +29 -29
  151. package/src/interface/IMdmOrgQuery.ts +13 -13
  152. package/src/interface/IOrgDeptInfo.ts +12 -12
  153. package/src/interface/ISysDictDataCacheVo.ts +46 -46
  154. package/src/interface/ISysDictType.ts +37 -37
  155. package/src/interface/ISysMenuDataVo.ts +22 -22
  156. package/src/interface/ISysMenuInfoVo.ts +83 -83
  157. package/src/interface/ISysMenuOperationVo.ts +21 -21
  158. package/src/interface/ISysUploadFiles.ts +16 -16
  159. package/src/interface/ISysUserInfo.ts +70 -70
  160. package/src/interface/IUserPermissionVo.ts +34 -34
  161. package/src/interface/Message.ts +73 -73
  162. package/src/interface/PageData.ts +17 -17
  163. package/src/interface/ResponseData.ts +16 -16
  164. package/src/interface/dictMapType.ts +11 -11
  165. package/src/interface/enum/MessageEnum.ts +41 -41
  166. package/src/interface/workflow/IWfProcessDefVo.ts +14 -14
  167. package/src/interface/workflow/IWfReturnNodeVo.ts +15 -16
  168. package/src/interface/workflow/IWfTaskAskVo.ts +61 -65
  169. package/src/interface/workflow/IWfTaskQueryVo.ts +30 -30
  170. package/src/interface/workflow/IWfTaskUsersVo.ts +21 -21
  171. package/src/interface/workflow/IWfTaskVo.ts +187 -187
  172. package/src/interface/workflow/workflow.ts +22 -22
  173. package/src/mixin/globalMixin.ts +45 -45
  174. package/src/packages/index.ts +18 -18
  175. package/src/packages/text.vue +13 -13
  176. package/src/plugins/echartsConfig.ts +73 -73
  177. package/src/plugins/plugins.ts +12 -12
  178. package/src/plugins/renderDialog.ts +74 -74
  179. package/src/stores/dictStore.ts +51 -51
  180. package/src/stores/messageStore.ts +49 -49
  181. package/src/stores/permissionStore.ts +108 -108
  182. package/src/stores/storeConfig.ts +23 -23
  183. package/src/stores/userInfoStore.ts +31 -31
  184. package/src/utils/AxiosConfig.ts +219 -219
  185. package/src/utils/modules.ts +8 -8
  186. package/src/utils/request.ts +76 -76
  187. package/adtec-core-package/adtec-core-package.css +0 -1
  188. package/adtec-core-package/adtec-core-package.js +0 -41605
  189. package/adtec-core-package/adtec-core-package.umd.cjs +0 -79
  190. package/adtec-core-package/favicon.ico +0 -0
@@ -1,226 +1,226 @@
1
- <!--创建人 xux-->
2
- <!--说明: ProcessInstanceStep-->
3
- <!--创建时间: 2024/11/20 上午10:49-->
4
- <!--修改时间: 2024/11/20 上午10:49-->
5
- <script setup lang="ts">
6
- import workbenchInstApi from '../../../api/workflow/workflowInstApi'
7
- import { ElMessage } from 'element-plus'
8
- import { ref } from 'vue'
9
- import type { IWfProcessInstVo, IWfTaskVo } from '../../../interface/workflow/IWfTaskVo'
10
- import ElUploads from '../../../components/upload/ElUploads.vue'
11
- import type { ISysUploadFiles } from '../../../interface/ISysUploadFiles'
12
- import documentApi from '../../../api/DocumentApi'
13
- import frameworkUtils from '../../../utils/FrameworkUtils.ts'
14
- const props = withDefaults(
15
- defineProps<{
16
- procInstId: string
17
- }>(),
18
- {
19
- procInstId: '',
20
- },
21
- )
22
- const loading = ref<boolean>(false)
23
- const wfProcessInstVo = ref<IWfProcessInstVo>()
24
- interface IWfTaskGroup {
25
- taskName: string
26
- taskDefKey: string
27
- parentExecutionId: string
28
- createTime: string
29
- finishTime: string
30
- tasks: IWfTaskVo[]
31
- }
32
- const taskGroup = ref<IWfTaskGroup[]>()
33
- const taskFiles = ref<ISysUploadFiles[]>([])
34
- const init = async (procInstId: string) => {
35
- if (!procInstId) return
36
- try {
37
- loading.value = true
38
- wfProcessInstVo.value = await workbenchInstApi.getProcessTaskList(procInstId)
39
- taskGroup.value = []
40
- if (wfProcessInstVo.value?.hisTasks?.length) {
41
- setTaskGroup(wfProcessInstVo.value.hisTasks || [])
42
- if (wfProcessInstVo.value.hisTasks.length > 0) {
43
- await documentApi
44
- .getUpLoadFilesByBussinessIds(wfProcessInstVo.value.hisTasks.map((item) => item.taskId))
45
- .then((res) => {
46
- taskFiles.value = res
47
- })
48
- .catch((err) => {
49
- frameworkUtils.messageError(err)
50
- })
51
- }
52
- }
53
- if (wfProcessInstVo.value?.activeTasks?.length) {
54
- setTaskGroup(wfProcessInstVo.value.activeTasks || [])
55
- }
56
- } catch (err: any) {
57
- taskGroup.value = []
58
- frameworkUtils.messageError(err)
59
- } finally {
60
- loading.value = false
61
- }
62
- }
63
- const setTaskGroup = (tasks: IWfTaskVo[]) => {
64
- taskGroup.value = taskGroup.value || []
65
- for (const hisTask of tasks) {
66
- const exist = taskGroup.value.find(
67
- (x) =>
68
- x.taskDefKey === hisTask.taskDefKey && x.parentExecutionId === hisTask.parentExecutionId,
69
- )
70
- if (exist) {
71
- if (hisTask.finishTime && hisTask.finishTime > exist.finishTime) {
72
- exist.finishTime = hisTask.finishTime
73
- }
74
- if (hisTask.createTime && hisTask.createTime < exist.createTime) {
75
- exist.createTime = hisTask.createTime
76
- }
77
- if (!hisTask.finishTime) {
78
- const eTask = exist.tasks.find((x) => !x.finishTime)
79
- if (eTask) {
80
- eTask.assigneeName += '/' + hisTask.assigneeName
81
- } else {
82
- exist.tasks.push(hisTask)
83
- }
84
- } else {
85
- exist.tasks.push(hisTask)
86
- }
87
- } else {
88
- taskGroup.value.push({
89
- taskName: hisTask.taskName || '',
90
- taskDefKey: hisTask.taskDefKey || '',
91
- parentExecutionId: hisTask.parentExecutionId || '',
92
- finishTime: hisTask.finishTime || '',
93
- createTime: hisTask.createTime || '',
94
- tasks: [hisTask],
95
- })
96
- }
97
- }
98
- if (taskGroup.value.length > 0) {
99
- taskGroup.value.sort((a, b) => {
100
- const n1 = (a.finishTime ? a.finishTime : '9999').localeCompare(
101
- b.finishTime ? b.finishTime : '9999',
102
- )
103
- if (n1 == 0) {
104
- return a.createTime.localeCompare(b.createTime)
105
- }
106
- return n1
107
- })
108
- }
109
- }
110
- const getStatus = (task: IWfTaskVo) => {
111
- if (!task.finishTime) {
112
- if (task.operations && task.operations === 'assignee') {
113
- return '待指定审批人'
114
- }
115
- return '待办'
116
- } else {
117
- if (task.taskLocalVars && task.taskLocalVars.firstTask) {
118
- return '已提交'
119
- }
120
- if (task.commentList && task.commentList.length > 0) {
121
- return ['待办', '已办', '退回', '驳回', '委派', '转办', '终止', '撤回'][
122
- Number(task.commentList[task.commentList.length - 1].type)
123
- ]
124
- }
125
- return '已办'
126
- }
127
- }
128
- defineExpose({
129
- init,
130
- })
131
- </script>
132
-
133
- <template>
134
- <el-flex justify="space-around" align="center" v-loading="loading" width="100%">
135
- <el-steps direction="vertical" align-center :space="160">
136
- <el-step
137
- v-for="item in taskGroup"
138
- :key="item.parentExecutionId"
139
- :status="item.tasks.find((x) => !x.finishTime) ? 'finish' : 'success'"
140
- >
141
- <!-- <template #icon>-->
142
- <!-- <flow-icon :name="getIcon(item.tasks)" :size="20" />-->
143
- <!-- </template>-->
144
- <template #title>
145
- <span style="display: block">{{ item.taskName }}</span>
146
- </template>
147
- <template #description>
148
- <el-flex
149
- :vertical="false"
150
- style="max-height: 300px; max-width: 690px; min-width: 150px; min-height: 60px"
151
- justify="flex-start"
152
- >
153
- <el-flex
154
- :vertical="true"
155
- v-for="task in item.tasks"
156
- :key="task.taskId"
157
- width="170px"
158
- style="
159
- margin-bottom: 5px;
160
- padding: 5px;
161
- margin-right: 5px;
162
- border-radius: 8px;
163
- background: #f8f8f8;
164
- "
165
- >
166
- <el-flex height="30px" align="center" justify="space-between">
167
- <el-tooltip
168
- v-if="task.assigneeName"
169
- :content="task.assigneeName"
170
- placement="top"
171
- effect="light"
172
- >
173
- <span class="ellipsis" style="font-size: 14px">{{ task.assigneeName }}</span>
174
- </el-tooltip>
175
- <el-tag size="small" :type="task.finishTime ? 'success' : 'primary'">{{
176
- getStatus(task)
177
- }}</el-tag>
178
- </el-flex>
179
- <el-tooltip
180
- v-if="task.comment"
181
- :content="task.comment"
182
- placement="top"
183
- effect="light"
184
- >
185
- <span class="ellipsis">{{ task.comment }}</span>
186
- </el-tooltip>
187
- <el-flex v-if="taskFiles.some((x) => x.businessId === task.taskId)" width="160px">
188
- <!-- <span style="font-size: 14px">附件:</span>-->
189
- <el-uploads
190
- :is-edlt="false"
191
- :vertical="true"
192
- :businessId="task.taskId"
193
- :upload-files-list="taskFiles.filter((x) => x.businessId === task.taskId)"
194
- ></el-uploads>
195
- </el-flex>
196
-
197
- <span style="display: block; color: #909399" v-if="task.comment">{{
198
- task.finishTime
199
- }}</span>
200
- </el-flex>
201
- </el-flex>
202
- </template>
203
- </el-step>
204
- </el-steps>
205
- </el-flex>
206
- </template>
207
-
208
- <style scoped lang="scss">
209
- .ellipsis {
210
- display: inline-block; /* 或 block */
211
- max-width: 100%; /* 设置宽度 */
212
- overflow: hidden; /* 隐藏超出的内容 */
213
- white-space: nowrap; /* 强制不换行 */
214
- text-overflow: ellipsis; /* 超出显示省略号 */
215
- min-height: 20px;
216
- font-size: 14px;
217
- }
218
-
219
- :deep .el-step__line {
220
- background-color: transparent;
221
- border: 1.5px solid;
222
- }
223
- :deep .el-step__description {
224
- padding: 0;
225
- }
226
- </style>
1
+ <!--创建人 xux-->
2
+ <!--说明: ProcessInstanceStep-->
3
+ <!--创建时间: 2024/11/20 上午10:49-->
4
+ <!--修改时间: 2024/11/20 上午10:49-->
5
+ <script setup lang="ts">
6
+ import workbenchInstApi from '../../../api/workflow/workflowInstApi'
7
+ import { ElMessage } from 'element-plus'
8
+ import { ref } from 'vue'
9
+ import type { IWfProcessInstVo, IWfTaskVo } from '../../../interface/workflow/IWfTaskVo'
10
+ import ElUploads from '../../../components/upload/ElUploads.vue'
11
+ import type { ISysUploadFiles } from '../../../interface/ISysUploadFiles'
12
+ import documentApi from '../../../api/DocumentApi'
13
+ import frameworkUtils from '../../../utils/FrameworkUtils.ts'
14
+ const props = withDefaults(
15
+ defineProps<{
16
+ procInstId: string
17
+ }>(),
18
+ {
19
+ procInstId: '',
20
+ },
21
+ )
22
+ const loading = ref<boolean>(false)
23
+ const wfProcessInstVo = ref<IWfProcessInstVo>()
24
+ interface IWfTaskGroup {
25
+ taskName: string
26
+ taskDefKey: string
27
+ parentExecutionId: string
28
+ createTime: string
29
+ finishTime: string
30
+ tasks: IWfTaskVo[]
31
+ }
32
+ const taskGroup = ref<IWfTaskGroup[]>()
33
+ const taskFiles = ref<ISysUploadFiles[]>([])
34
+ const init = async (procInstId: string) => {
35
+ if (!procInstId) return
36
+ try {
37
+ loading.value = true
38
+ wfProcessInstVo.value = await workbenchInstApi.getProcessTaskList(procInstId)
39
+ taskGroup.value = []
40
+ if (wfProcessInstVo.value?.hisTasks?.length) {
41
+ setTaskGroup(wfProcessInstVo.value.hisTasks || [])
42
+ if (wfProcessInstVo.value.hisTasks.length > 0) {
43
+ await documentApi
44
+ .getUpLoadFilesByBussinessIds(wfProcessInstVo.value.hisTasks.map((item) => item.taskId))
45
+ .then((res) => {
46
+ taskFiles.value = res
47
+ })
48
+ .catch((err) => {
49
+ frameworkUtils.messageError(err)
50
+ })
51
+ }
52
+ }
53
+ if (wfProcessInstVo.value?.activeTasks?.length) {
54
+ setTaskGroup(wfProcessInstVo.value.activeTasks || [])
55
+ }
56
+ } catch (err: any) {
57
+ taskGroup.value = []
58
+ frameworkUtils.messageError(err)
59
+ } finally {
60
+ loading.value = false
61
+ }
62
+ }
63
+ const setTaskGroup = (tasks: IWfTaskVo[]) => {
64
+ taskGroup.value = taskGroup.value || []
65
+ for (const hisTask of tasks) {
66
+ const exist = taskGroup.value.find(
67
+ (x) =>
68
+ x.taskDefKey === hisTask.taskDefKey && x.parentExecutionId === hisTask.parentExecutionId,
69
+ )
70
+ if (exist) {
71
+ if (hisTask.finishTime && hisTask.finishTime > exist.finishTime) {
72
+ exist.finishTime = hisTask.finishTime
73
+ }
74
+ if (hisTask.createTime && hisTask.createTime < exist.createTime) {
75
+ exist.createTime = hisTask.createTime
76
+ }
77
+ if (!hisTask.finishTime) {
78
+ const eTask = exist.tasks.find((x) => !x.finishTime)
79
+ if (eTask) {
80
+ eTask.assigneeName += '/' + hisTask.assigneeName
81
+ } else {
82
+ exist.tasks.push(hisTask)
83
+ }
84
+ } else {
85
+ exist.tasks.push(hisTask)
86
+ }
87
+ } else {
88
+ taskGroup.value.push({
89
+ taskName: hisTask.taskName || '',
90
+ taskDefKey: hisTask.taskDefKey || '',
91
+ parentExecutionId: hisTask.parentExecutionId || '',
92
+ finishTime: hisTask.finishTime || '',
93
+ createTime: hisTask.createTime || '',
94
+ tasks: [hisTask],
95
+ })
96
+ }
97
+ }
98
+ if (taskGroup.value.length > 0) {
99
+ taskGroup.value.sort((a, b) => {
100
+ const n1 = (a.finishTime ? a.finishTime : '9999').localeCompare(
101
+ b.finishTime ? b.finishTime : '9999',
102
+ )
103
+ if (n1 == 0) {
104
+ return a.createTime.localeCompare(b.createTime)
105
+ }
106
+ return n1
107
+ })
108
+ }
109
+ }
110
+ const getStatus = (task: IWfTaskVo) => {
111
+ if (!task.finishTime) {
112
+ if (task.operations && task.operations === 'assignee') {
113
+ return '待指定审批人'
114
+ }
115
+ return '待办'
116
+ } else {
117
+ if (task.taskLocalVars && task.taskLocalVars.firstTask) {
118
+ return '已提交'
119
+ }
120
+ if (task.commentList && task.commentList.length > 0) {
121
+ return ['待办', '已办', '退回', '驳回', '委派', '转办', '终止', '撤回'][
122
+ Number(task.commentList[task.commentList.length - 1].type)
123
+ ]
124
+ }
125
+ return '已办'
126
+ }
127
+ }
128
+ defineExpose({
129
+ init,
130
+ })
131
+ </script>
132
+
133
+ <template>
134
+ <el-flex justify="space-around" align="center" v-loading="loading" width="100%">
135
+ <el-steps direction="vertical" align-center :space="160">
136
+ <el-step
137
+ v-for="item in taskGroup"
138
+ :key="item.parentExecutionId"
139
+ :status="item.tasks.find((x) => !x.finishTime) ? 'finish' : 'success'"
140
+ >
141
+ <!-- <template #icon>-->
142
+ <!-- <flow-icon :name="getIcon(item.tasks)" :size="20" />-->
143
+ <!-- </template>-->
144
+ <template #title>
145
+ <span style="display: block">{{ item.taskName }}</span>
146
+ </template>
147
+ <template #description>
148
+ <el-flex
149
+ :vertical="false"
150
+ style="max-height: 300px; max-width: 690px; min-width: 150px; min-height: 60px"
151
+ justify="flex-start"
152
+ >
153
+ <el-flex
154
+ :vertical="true"
155
+ v-for="task in item.tasks"
156
+ :key="task.taskId"
157
+ width="170px"
158
+ style="
159
+ margin-bottom: 5px;
160
+ padding: 5px;
161
+ margin-right: 5px;
162
+ border-radius: 8px;
163
+ background: #f8f8f8;
164
+ "
165
+ >
166
+ <el-flex height="30px" align="center" justify="space-between">
167
+ <el-tooltip
168
+ v-if="task.assigneeName"
169
+ :content="task.assigneeName"
170
+ placement="top"
171
+ effect="light"
172
+ >
173
+ <span class="ellipsis" style="font-size: 14px">{{ task.assigneeName }}</span>
174
+ </el-tooltip>
175
+ <el-tag size="small" :type="task.finishTime ? 'success' : 'primary'">{{
176
+ getStatus(task)
177
+ }}</el-tag>
178
+ </el-flex>
179
+ <el-tooltip
180
+ v-if="task.comment"
181
+ :content="task.comment"
182
+ placement="top"
183
+ effect="light"
184
+ >
185
+ <span class="ellipsis">{{ task.comment }}</span>
186
+ </el-tooltip>
187
+ <el-flex v-if="taskFiles.some((x) => x.businessId === task.taskId)" width="160px">
188
+ <!-- <span style="font-size: 14px">附件:</span>-->
189
+ <el-uploads
190
+ :is-edlt="false"
191
+ :vertical="true"
192
+ :businessId="task.taskId"
193
+ :upload-files-list="taskFiles.filter((x) => x.businessId === task.taskId)"
194
+ ></el-uploads>
195
+ </el-flex>
196
+
197
+ <span style="display: block; color: #909399" v-if="task.comment">{{
198
+ task.finishTime
199
+ }}</span>
200
+ </el-flex>
201
+ </el-flex>
202
+ </template>
203
+ </el-step>
204
+ </el-steps>
205
+ </el-flex>
206
+ </template>
207
+
208
+ <style scoped lang="scss">
209
+ .ellipsis {
210
+ display: inline-block; /* 或 block */
211
+ max-width: 100%; /* 设置宽度 */
212
+ overflow: hidden; /* 隐藏超出的内容 */
213
+ white-space: nowrap; /* 强制不换行 */
214
+ text-overflow: ellipsis; /* 超出显示省略号 */
215
+ min-height: 20px;
216
+ font-size: 14px;
217
+ }
218
+
219
+ :deep .el-step__line {
220
+ background-color: transparent;
221
+ border: 1.5px solid;
222
+ }
223
+ :deep .el-step__description {
224
+ padding: 0;
225
+ }
226
+ </style>
@@ -1,109 +1,109 @@
1
- <!--创建人 xux-->
2
- <!--说明: SelectAssigneeDialog-->
3
- <!--创建时间: 2024/11/14 下午5:56-->
4
- <!--修改时间: 2024/11/14 下午5:56-->
5
- <template>
6
- <el-dialog v-model="dialogVisible" title="指定执行人" append-to-body width="450">
7
- <el-flex v-loading="loading" :vertical="true">
8
- <el-form
9
- v-for="(data, index) of datas"
10
- labelPosition="top"
11
- size="default"
12
- :style="{ width: '100%' }"
13
- >
14
- <el-form-item label="任务名">
15
- <span>{{ data?.taskName }}({{ data?.procName }})</span>
16
- </el-form-item>
17
- <el-form-item label="候选人" :required="true">
18
- <el-checkbox-group
19
- v-if="data?.candidate && data?.candidate.length > 0"
20
- v-model="data.assignee"
21
- >
22
- <el-checkbox
23
- style="width: 80px"
24
- v-for="user in data?.candidate"
25
- :key="user.id"
26
- :label="user.userName"
27
- :value="user.id"
28
- />
29
- </el-checkbox-group>
30
- </el-form-item>
31
- <el-divider v-if="index != datas?.length - 1"></el-divider>
32
- </el-form>
33
- </el-flex>
34
- <template #footer>
35
- <div class="dialog-footer">
36
- <el-button @click="dialogVisible = false">取消</el-button>
37
- <el-button type="primary" @click="save" :loading="loading">确定</el-button>
38
- </div>
39
- </template>
40
- </el-dialog>
41
- </template>
42
- <script setup lang="ts">
43
- import { ref } from 'vue'
44
- import workflowInstApi from '../../../api/workflow/workflowInstApi'
45
- import type { IWfTaskUsersVo } from '../../../interface/workflow/IWfTaskUsersVo'
46
- import { ElMessage } from 'element-plus'
47
- import frameworkUtils from '../../../utils/FrameworkUtils.ts'
48
- const emit = defineEmits(['success'])
49
- const datas = ref<IWfTaskUsersVo[]>([])
50
- const dialogVisible = ref(false)
51
- const loading = ref(false)
52
- const open = async (taskId: string) => {
53
- try {
54
- datas.value = [
55
- {
56
- assignee: [],
57
- },
58
- ]
59
- dialogVisible.value = true
60
- loading.value = true
61
- const taskUsers = await workflowInstApi.getTaskCandidateList(taskId)
62
- if (taskUsers?.length > 0) {
63
- for (let taskUser of taskUsers) {
64
- taskUser.assignee = []
65
- }
66
- datas.value = taskUsers
67
- } else {
68
- ElMessage.warning('无候选人数据')
69
- }
70
- } catch (err: any) {
71
- frameworkUtils.messageError(err)
72
- } finally {
73
- loading.value = false
74
- }
75
- }
76
- const save = async () => {
77
- for (let data of datas.value) {
78
- if (data.candidate?.length == 0 || data.assignee.length == 0) {
79
- ElMessage.warning('请指定执行人!')
80
- return
81
- }
82
- }
83
- try {
84
- loading.value = true
85
- await workflowInstApi.setAssigneeList(datas.value)
86
- ElMessage.success('操作成功')
87
- emit('success', '')
88
- dialogVisible.value = false
89
- } catch (err: any) {
90
- frameworkUtils.messageError(err)
91
- } finally {
92
- loading.value = false
93
- }
94
- }
95
-
96
- defineExpose({
97
- open,
98
- })
99
- </script>
100
- <style scoped lang="scss">
101
- :deep {
102
- .el-divider--horizontal {
103
- margin: 10px 0;
104
- }
105
- .el-checkbox {
106
- margin-right: 10px;
107
- }
108
- }
109
- </style>
1
+ <!--创建人 xux-->
2
+ <!--说明: SelectAssigneeDialog-->
3
+ <!--创建时间: 2024/11/14 下午5:56-->
4
+ <!--修改时间: 2024/11/14 下午5:56-->
5
+ <template>
6
+ <el-dialog v-model="dialogVisible" title="指定执行人" append-to-body width="450">
7
+ <el-flex v-loading="loading" :vertical="true">
8
+ <el-form
9
+ v-for="(data, index) of datas"
10
+ labelPosition="top"
11
+ size="default"
12
+ :style="{ width: '100%' }"
13
+ >
14
+ <el-form-item label="任务名">
15
+ <span>{{ data?.taskName }}({{ data?.procName }})</span>
16
+ </el-form-item>
17
+ <el-form-item label="候选人" :required="true">
18
+ <el-checkbox-group
19
+ v-if="data?.candidate && data?.candidate.length > 0"
20
+ v-model="data.assignee"
21
+ >
22
+ <el-checkbox
23
+ style="width: 80px"
24
+ v-for="user in data?.candidate"
25
+ :key="user.id"
26
+ :label="user.userName"
27
+ :value="user.id"
28
+ />
29
+ </el-checkbox-group>
30
+ </el-form-item>
31
+ <el-divider v-if="index != datas?.length - 1"></el-divider>
32
+ </el-form>
33
+ </el-flex>
34
+ <template #footer>
35
+ <div class="dialog-footer">
36
+ <el-button @click="dialogVisible = false">取消</el-button>
37
+ <el-button type="primary" @click="save" :loading="loading">确定</el-button>
38
+ </div>
39
+ </template>
40
+ </el-dialog>
41
+ </template>
42
+ <script setup lang="ts">
43
+ import { ref } from 'vue'
44
+ import workflowInstApi from '../../../api/workflow/workflowInstApi'
45
+ import type { IWfTaskUsersVo } from '../../../interface/workflow/IWfTaskUsersVo'
46
+ import { ElMessage } from 'element-plus'
47
+ import frameworkUtils from '../../../utils/FrameworkUtils.ts'
48
+ const emit = defineEmits(['success'])
49
+ const datas = ref<IWfTaskUsersVo[]>([])
50
+ const dialogVisible = ref(false)
51
+ const loading = ref(false)
52
+ const open = async (taskId: string) => {
53
+ try {
54
+ datas.value = [
55
+ {
56
+ assignee: [],
57
+ },
58
+ ]
59
+ dialogVisible.value = true
60
+ loading.value = true
61
+ const taskUsers = await workflowInstApi.getTaskCandidateList(taskId)
62
+ if (taskUsers?.length > 0) {
63
+ for (let taskUser of taskUsers) {
64
+ taskUser.assignee = []
65
+ }
66
+ datas.value = taskUsers
67
+ } else {
68
+ ElMessage.warning('无候选人数据')
69
+ }
70
+ } catch (err: any) {
71
+ frameworkUtils.messageError(err)
72
+ } finally {
73
+ loading.value = false
74
+ }
75
+ }
76
+ const save = async () => {
77
+ for (let data of datas.value) {
78
+ if (data.candidate?.length == 0 || data.assignee.length == 0) {
79
+ ElMessage.warning('请指定执行人!')
80
+ return
81
+ }
82
+ }
83
+ try {
84
+ loading.value = true
85
+ await workflowInstApi.setAssigneeList(datas.value)
86
+ ElMessage.success('操作成功')
87
+ emit('success', '')
88
+ dialogVisible.value = false
89
+ } catch (err: any) {
90
+ frameworkUtils.messageError(err)
91
+ } finally {
92
+ loading.value = false
93
+ }
94
+ }
95
+
96
+ defineExpose({
97
+ open,
98
+ })
99
+ </script>
100
+ <style scoped lang="scss">
101
+ :deep {
102
+ .el-divider--horizontal {
103
+ margin: 10px 0;
104
+ }
105
+ .el-checkbox {
106
+ margin-right: 10px;
107
+ }
108
+ }
109
+ </style>