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,115 +1,115 @@
1
- <script setup lang="ts">
2
- import Node from './Node.vue'
3
- import type { ErrorInfo, NotifyNode } from './type'
4
- import { inject, ref, type Ref, watchEffect } from 'vue'
5
- import { getRoleListById } from '../../../api/modules/role'
6
- import type { Field } from '../../../components/Render/type'
7
- import { getList } from '../../../api/modules/user'
8
-
9
- const props = defineProps<{
10
- node: NotifyNode
11
- }>()
12
- const { fields, nodesError } = inject<{
13
- fields: Ref<Field[]>
14
- nodesError: Ref<Recordable<ErrorInfo[]>>
15
- }>('flowDesign', { fields: ref([]), nodesError: ref({}) })
16
- const viewContent = ref<string>('')
17
- watchEffect(async () => {
18
- const errors: ErrorInfo[] = []
19
- const {
20
- id,
21
- assigneeType,
22
- name,
23
- users,
24
- roles,
25
- leader,
26
- choice,
27
- formUser,
28
- formRole,
29
- orgLeader,
30
- subject,
31
- types,
32
- content,
33
- nodeTag,
34
- } = props.node
35
- if (assigneeType === 'user') {
36
- if (users.length > 0) {
37
- try {
38
- const res = await getList(users)
39
- viewContent.value = res.map((user) => user.userName).join('、')
40
- } catch (err: any) {
41
- viewContent.value = err.msg
42
- }
43
- } else {
44
- errors.push({ id: id, name: name, message: '未指定人员' })
45
- viewContent.value = '未指定人员'
46
- }
47
- } else if (assigneeType === 'choice') {
48
- viewContent.value = `发起人自选(${choice ? '多选' : '单选'})`
49
- } else if (assigneeType === 'self') {
50
- viewContent.value = '发起人自己'
51
- } else if (assigneeType === 'leader') {
52
- viewContent.value = leader === 1 ? '直属上级' : `${leader}级上级`
53
- } else if (assigneeType === 'orgLeader') {
54
- viewContent.value = orgLeader === 1 ? '直属主管' : `${orgLeader}级主管`
55
- } else if (assigneeType === 'formUser') {
56
- if (!formUser) {
57
- errors.push({ id: id, name: name, message: '未指定自定义人员' })
58
- }
59
- const title = fields.value.find((e) => e.id === formUser)?.label || formUser || '?'
60
- viewContent.value = `自定义(${title})人员`
61
- } else if (assigneeType === 'formRole') {
62
- if (!formRole) {
63
- errors.push({ id: id, name: name, message: '未指定自定义角色' })
64
- }
65
- const title = fields.value.find((e) => e.id === formRole)?.label || formRole || '?'
66
- viewContent.value = `自定义(${title})角色`
67
- } else if (assigneeType === 'role') {
68
- if (roles.length > 0) {
69
- // const all = roles.map((id) => getById(id))
70
- // Promise.all(all).then((roles) => {
71
- // viewContent.value = roles.map((res) => res.data.name).join('、')
72
- // })
73
- try {
74
- const res = await getRoleListById(roles)
75
- viewContent.value = res.map((role) => role.name).join('、')
76
- } catch (err: any) {
77
- viewContent.value = err.msg
78
- }
79
- } else {
80
- errors.push({ id: id, name: name, message: '未指定角色' })
81
- viewContent.value = '未指定角色'
82
- }
83
- } else {
84
- errors.push({ id: id, name: name, message: '未知错误' })
85
- viewContent.value = name
86
- }
87
-
88
- if (types.length === 0) {
89
- errors.push({ id: id, name: name, message: '未指定通知类型' })
90
- }
91
- if (!subject) {
92
- errors.push({ id: id, name: name, message: '消息主题为空' })
93
- }
94
- if (!content) {
95
- errors.push({ id: id, name: name, message: '消息内容为空' })
96
- }
97
- if (!nodeTag) {
98
- errors.push({ id: id, name: name, message: '未设置组件路径' })
99
- }
100
- // 记录错误
101
- if (errors.length > 0) {
102
- nodesError.value[id] = errors
103
- } else {
104
- delete nodesError.value[id]
105
- }
106
- })
107
- </script>
108
-
109
- <template>
110
- <Node v-bind="$attrs" icon="el:BellFilled" color="#4292F3" :node="node">
111
- <el-text>{{ viewContent }}</el-text>
112
- </Node>
113
- </template>
114
-
115
- <style scoped lang="scss"></style>
1
+ <script setup lang="ts">
2
+ import Node from './Node.vue'
3
+ import type { ErrorInfo, NotifyNode } from './type'
4
+ import { inject, ref, type Ref, watchEffect } from 'vue'
5
+ import { getRoleListById } from '../../../api/modules/role'
6
+ import type { Field } from '../../../components/Render/type'
7
+ import { getList } from '../../../api/modules/user'
8
+
9
+ const props = defineProps<{
10
+ node: NotifyNode
11
+ }>()
12
+ const { fields, nodesError } = inject<{
13
+ fields: Ref<Field[]>
14
+ nodesError: Ref<Recordable<ErrorInfo[]>>
15
+ }>('flowDesign', { fields: ref([]), nodesError: ref({}) })
16
+ const viewContent = ref<string>('')
17
+ watchEffect(async () => {
18
+ const errors: ErrorInfo[] = []
19
+ const {
20
+ id,
21
+ assigneeType,
22
+ name,
23
+ users,
24
+ roles,
25
+ leader,
26
+ choice,
27
+ formUser,
28
+ formRole,
29
+ orgLeader,
30
+ subject,
31
+ types,
32
+ content,
33
+ nodeTag,
34
+ } = props.node
35
+ if (assigneeType === 'user') {
36
+ if (users.length > 0) {
37
+ try {
38
+ const res = await getList(users)
39
+ viewContent.value = res.map((user) => user.userName).join('、')
40
+ } catch (err: any) {
41
+ viewContent.value = err.msg
42
+ }
43
+ } else {
44
+ errors.push({ id: id, name: name, message: '未指定人员' })
45
+ viewContent.value = '未指定人员'
46
+ }
47
+ } else if (assigneeType === 'choice') {
48
+ viewContent.value = `发起人自选(${choice ? '多选' : '单选'})`
49
+ } else if (assigneeType === 'self') {
50
+ viewContent.value = '发起人自己'
51
+ } else if (assigneeType === 'leader') {
52
+ viewContent.value = leader === 1 ? '直属上级' : `${leader}级上级`
53
+ } else if (assigneeType === 'orgLeader') {
54
+ viewContent.value = orgLeader === 1 ? '直属主管' : `${orgLeader}级主管`
55
+ } else if (assigneeType === 'formUser') {
56
+ if (!formUser) {
57
+ errors.push({ id: id, name: name, message: '未指定自定义人员' })
58
+ }
59
+ const title = fields.value.find((e) => e.id === formUser)?.label || formUser || '?'
60
+ viewContent.value = `自定义(${title})人员`
61
+ } else if (assigneeType === 'formRole') {
62
+ if (!formRole) {
63
+ errors.push({ id: id, name: name, message: '未指定自定义角色' })
64
+ }
65
+ const title = fields.value.find((e) => e.id === formRole)?.label || formRole || '?'
66
+ viewContent.value = `自定义(${title})角色`
67
+ } else if (assigneeType === 'role') {
68
+ if (roles.length > 0) {
69
+ // const all = roles.map((id) => getById(id))
70
+ // Promise.all(all).then((roles) => {
71
+ // viewContent.value = roles.map((res) => res.data.name).join('、')
72
+ // })
73
+ try {
74
+ const res = await getRoleListById(roles)
75
+ viewContent.value = res.map((role) => role.name).join('、')
76
+ } catch (err: any) {
77
+ viewContent.value = err.msg
78
+ }
79
+ } else {
80
+ errors.push({ id: id, name: name, message: '未指定角色' })
81
+ viewContent.value = '未指定角色'
82
+ }
83
+ } else {
84
+ errors.push({ id: id, name: name, message: '未知错误' })
85
+ viewContent.value = name
86
+ }
87
+
88
+ if (types.length === 0) {
89
+ errors.push({ id: id, name: name, message: '未指定通知类型' })
90
+ }
91
+ if (!subject) {
92
+ errors.push({ id: id, name: name, message: '消息主题为空' })
93
+ }
94
+ if (!content) {
95
+ errors.push({ id: id, name: name, message: '消息内容为空' })
96
+ }
97
+ if (!nodeTag) {
98
+ errors.push({ id: id, name: name, message: '未设置组件路径' })
99
+ }
100
+ // 记录错误
101
+ if (errors.length > 0) {
102
+ nodesError.value[id] = errors
103
+ } else {
104
+ delete nodesError.value[id]
105
+ }
106
+ })
107
+ </script>
108
+
109
+ <template>
110
+ <Node v-bind="$attrs" icon="el:BellFilled" color="#4292F3" :node="node">
111
+ <el-text>{{ viewContent }}</el-text>
112
+ </Node>
113
+ </template>
114
+
115
+ <style scoped lang="scss"></style>
@@ -1,20 +1,20 @@
1
- <script setup lang="ts">
2
- import type { ParallelNode } from './type'
3
- import GatewayNode from './GatewayNode.vue'
4
-
5
- defineProps<{
6
- node: ParallelNode
7
- }>()
8
- </script>
9
-
10
- <template>
11
- <GatewayNode v-bind="$attrs" :node="node">
12
- <template #default="{ addNode, readOnly }">
13
- <el-button type="primary" :disabled="readOnly" @click="addNode('concurrent', node)" plain round
14
- >添加并行分支</el-button
15
- >
16
- </template>
17
- </GatewayNode>
18
- </template>
19
-
20
- <style scoped lang="scss"></style>
1
+ <script setup lang="ts">
2
+ import type { ParallelNode } from './type'
3
+ import GatewayNode from './GatewayNode.vue'
4
+
5
+ defineProps<{
6
+ node: ParallelNode
7
+ }>()
8
+ </script>
9
+
10
+ <template>
11
+ <GatewayNode v-bind="$attrs" :node="node">
12
+ <template #default="{ addNode, readOnly }">
13
+ <el-button type="primary" :disabled="readOnly" @click="addNode('concurrent', node)" plain round
14
+ >添加并行分支</el-button
15
+ >
16
+ </template>
17
+ </GatewayNode>
18
+ </template>
19
+
20
+ <style scoped lang="scss"></style>
@@ -1,78 +1,78 @@
1
- <!--创建人 xux-->
2
- <!--说明: PopoverView-->
3
- <!--创建时间: 2024/11/13 下午10:49-->
4
- <!--修改时间: 2024/11/13 下午10:49-->
5
- <template>
6
- <div v-for="(item, index) in tasks" :key="item.taskId" style="width: 100%">
7
- <el-row style="height: 20px">
8
- <el-col :span="24">
9
- <el-tooltip
10
- v-if="item.assigneeName"
11
- :content="item.assigneeName"
12
- placement="top"
13
- effect="light"
14
- >
15
- <span class="ellipsis">处理人:{{ item.assigneeName }}</span>
16
- </el-tooltip>
17
- </el-col>
18
- </el-row>
19
- <el-row>
20
- <el-col :span="24">开始时间:{{ item.createTime }}</el-col>
21
- </el-row>
22
- <el-row v-if="item.finishTime">
23
- <el-col :span="24">结束时间:{{ item.finishTime }}</el-col>
24
- </el-row>
25
- <el-row v-if="item.commentList?.[0]?.fullMessage">
26
- <el-col :span="24"
27
- >处理意见:{{ item.commentList?.[item.commentList.length - 1]?.fullMessage }}</el-col
28
- >
29
- </el-row>
30
- <el-row>
31
- <el-col :span="24">状态:{{ getStatus(item) }}</el-col>
32
- </el-row>
33
- <el-row v-if="tasks.length > 0 && index != tasks.length - 1">
34
- <el-col :span="24">
35
- <el-divider style="margin: 5px 0"></el-divider>
36
- </el-col>
37
- </el-row>
38
- </div>
39
- </template>
40
- <script setup lang="ts">
41
- import { computed } from 'vue'
42
- import type { IWfTaskVo } from '../../../../../interface/workflow/IWfTaskVo'
43
- import type { FlowNode } from '../../../views/flowDesign/nodes/type'
44
- const getStatus = (task: IWfTaskVo) => {
45
- if (!task.finishTime) {
46
- if (task.operations && task.operations === 'assignee') {
47
- return '待指定审批人'
48
- }
49
- return '待办'
50
- } else {
51
- if (task.taskLocalVars && task.taskLocalVars.firstTask) {
52
- return '已提交'
53
- }
54
- if (task.commentList && task.commentList.length > 0) {
55
- return ['待办', '已办', '退回', '驳回', '委派', '转办', '终止', '撤回'][
56
- Number(task.commentList[task.commentList.length - 1].type)
57
- ]
58
- }
59
- return '已办'
60
- }
61
- }
62
- const props = defineProps<{
63
- node: FlowNode
64
- tasks: IWfTaskVo[]
65
- }>()
66
- const tasks = computed(() => {
67
- return props.tasks.filter((x) => !(x.finishTime && x.commentList?.length == 0))
68
- })
69
- </script>
70
- <style scoped lang="scss">
71
- .ellipsis {
72
- display: inline-block; /* 或 block */
73
- max-width: 100%; /* 设置宽度 */
74
- overflow: hidden; /* 隐藏超出的内容 */
75
- white-space: nowrap; /* 强制不换行 */
76
- text-overflow: ellipsis; /* 超出显示省略号 */
77
- }
78
- </style>
1
+ <!--创建人 xux-->
2
+ <!--说明: PopoverView-->
3
+ <!--创建时间: 2024/11/13 下午10:49-->
4
+ <!--修改时间: 2024/11/13 下午10:49-->
5
+ <template>
6
+ <div v-for="(item, index) in tasks" :key="item.taskId" style="width: 100%">
7
+ <el-row style="height: 20px">
8
+ <el-col :span="24">
9
+ <el-tooltip
10
+ v-if="item.assigneeName"
11
+ :content="item.assigneeName"
12
+ placement="top"
13
+ effect="light"
14
+ >
15
+ <span class="ellipsis">处理人:{{ item.assigneeName }}</span>
16
+ </el-tooltip>
17
+ </el-col>
18
+ </el-row>
19
+ <el-row>
20
+ <el-col :span="24">开始时间:{{ item.createTime }}</el-col>
21
+ </el-row>
22
+ <el-row v-if="item.finishTime">
23
+ <el-col :span="24">结束时间:{{ item.finishTime }}</el-col>
24
+ </el-row>
25
+ <el-row v-if="item.commentList?.[0]?.fullMessage">
26
+ <el-col :span="24"
27
+ >处理意见:{{ item.commentList?.[item.commentList.length - 1]?.fullMessage }}</el-col
28
+ >
29
+ </el-row>
30
+ <el-row>
31
+ <el-col :span="24">状态:{{ getStatus(item) }}</el-col>
32
+ </el-row>
33
+ <el-row v-if="tasks.length > 0 && index != tasks.length - 1">
34
+ <el-col :span="24">
35
+ <el-divider style="margin: 5px 0"></el-divider>
36
+ </el-col>
37
+ </el-row>
38
+ </div>
39
+ </template>
40
+ <script setup lang="ts">
41
+ import { computed } from 'vue'
42
+ import type { IWfTaskVo } from '../../../../../interface/workflow/IWfTaskVo'
43
+ import type { FlowNode } from '../../../views/flowDesign/nodes/type'
44
+ const getStatus = (task: IWfTaskVo) => {
45
+ if (!task.finishTime) {
46
+ if (task.operations && task.operations === 'assignee') {
47
+ return '待指定审批人'
48
+ }
49
+ return '待办'
50
+ } else {
51
+ if (task.taskLocalVars && task.taskLocalVars.firstTask) {
52
+ return '已提交'
53
+ }
54
+ if (task.commentList && task.commentList.length > 0) {
55
+ return ['待办', '已办', '退回', '驳回', '委派', '转办', '终止', '撤回'][
56
+ Number(task.commentList[task.commentList.length - 1].type)
57
+ ]
58
+ }
59
+ return '已办'
60
+ }
61
+ }
62
+ const props = defineProps<{
63
+ node: FlowNode
64
+ tasks: IWfTaskVo[]
65
+ }>()
66
+ const tasks = computed(() => {
67
+ return props.tasks.filter((x) => !(x.finishTime && x.commentList?.length == 0))
68
+ })
69
+ </script>
70
+ <style scoped lang="scss">
71
+ .ellipsis {
72
+ display: inline-block; /* 或 block */
73
+ max-width: 100%; /* 设置宽度 */
74
+ overflow: hidden; /* 隐藏超出的内容 */
75
+ white-space: nowrap; /* 强制不换行 */
76
+ text-overflow: ellipsis; /* 超出显示省略号 */
77
+ }
78
+ </style>
@@ -1,84 +1,84 @@
1
- <script setup lang="ts">
2
- import Node from './Node.vue'
3
- import type { ErrorInfo, FlowNode, NodeType, StartNode } from './type'
4
- import { computed, inject, ref, type Ref, watchEffect } from 'vue'
5
- import Add from './Add.vue'
6
- import type { IWfProcessInstVo } from '../../../../../interface/workflow/IWfTaskVo'
7
-
8
- const props = defineProps<{
9
- node: StartNode
10
- }>()
11
- const _inject = inject<{
12
- nodesError: Ref<Recordable<ErrorInfo[]>>
13
- readOnly?: Ref<boolean>
14
- processInst: Ref<IWfProcessInstVo>
15
- }>('flowDesign', {
16
- nodesError: ref({}),
17
- readOnly: ref(false),
18
- processInst: ref<IWfProcessInstVo>({}),
19
- })
20
- const $emits = defineEmits<{
21
- (e: 'addNode', type: NodeType, node: FlowNode): void
22
- (e: 'activeNode', node: FlowNode): void
23
- }>()
24
- const iconColor = ref('#0b83de')
25
- watchEffect(() => {
26
- // const errors: ErrorInfo[] = []
27
- // const { id, name, child } = props.node
28
- // if (child?.type === 'end') {
29
- // errors.push({ id: id, name: name, message: '发起下节点为空' })
30
- // }
31
- if (_inject.processInst.value && props.node) {
32
- iconColor.value = '#18ad43'
33
- }
34
- })
35
- const _readOnly = computed(() => _inject.readOnly?.value)
36
- const activeNode = () => {
37
- if (_readOnly.value) return
38
- $emits('activeNode', props.node)
39
- }
40
- const addNode = (type: NodeType) => {
41
- $emits('addNode', type, props.node)
42
- }
43
- </script>
44
-
45
- <template>
46
- <div class="node-box">
47
- <!-- <div class="end-node-circle"></div>-->
48
- <el-flex class="start-node" @click="activeNode" align="center">
49
- <el-icons model-value="adtec-start" size="30"></el-icons>
50
- <!-- <el-text>流程开启</el-text>-->
51
- </el-flex>
52
- <Add @add-node="addNode" />
53
- </div>
54
- </template>
55
-
56
- <style scoped lang="scss">
57
- .node-box {
58
- position: relative;
59
- padding-bottom: 0;
60
- padding-top: 40px;
61
- //.end-node-circle {
62
- // width: 10px;
63
- // height: 10px;
64
- // border-radius: 50%;
65
- // background-color: var(--el-border-color);
66
- // margin: auto auto 5px;
67
- //}
68
-
69
- .start-node {
70
- position: relative;
71
- background: white; //var(--el-border-color-lighter);
72
- padding: 6px;
73
- border-radius: 24px;
74
- cursor: pointer;
75
- overflow: visible;
76
- z-index: 10;
77
- box-shadow: var(--el-box-shadow-light);
78
- color: v-bind(iconColor); //#0b83de; //#18ad43;
79
- &:hover {
80
- box-shadow: 0 0 5px 0 var(--el-color-primary);
81
- }
82
- }
83
- }
84
- </style>
1
+ <script setup lang="ts">
2
+ import Node from './Node.vue'
3
+ import type { ErrorInfo, FlowNode, NodeType, StartNode } from './type'
4
+ import { computed, inject, ref, type Ref, watchEffect } from 'vue'
5
+ import Add from './Add.vue'
6
+ import type { IWfProcessInstVo } from '../../../../../interface/workflow/IWfTaskVo'
7
+
8
+ const props = defineProps<{
9
+ node: StartNode
10
+ }>()
11
+ const _inject = inject<{
12
+ nodesError: Ref<Recordable<ErrorInfo[]>>
13
+ readOnly?: Ref<boolean>
14
+ processInst: Ref<IWfProcessInstVo>
15
+ }>('flowDesign', {
16
+ nodesError: ref({}),
17
+ readOnly: ref(false),
18
+ processInst: ref<IWfProcessInstVo>({}),
19
+ })
20
+ const $emits = defineEmits<{
21
+ (e: 'addNode', type: NodeType, node: FlowNode): void
22
+ (e: 'activeNode', node: FlowNode): void
23
+ }>()
24
+ const iconColor = ref('#0b83de')
25
+ watchEffect(() => {
26
+ // const errors: ErrorInfo[] = []
27
+ // const { id, name, child } = props.node
28
+ // if (child?.type === 'end') {
29
+ // errors.push({ id: id, name: name, message: '发起下节点为空' })
30
+ // }
31
+ if (_inject.processInst.value && props.node) {
32
+ iconColor.value = '#18ad43'
33
+ }
34
+ })
35
+ const _readOnly = computed(() => _inject.readOnly?.value)
36
+ const activeNode = () => {
37
+ if (_readOnly.value) return
38
+ $emits('activeNode', props.node)
39
+ }
40
+ const addNode = (type: NodeType) => {
41
+ $emits('addNode', type, props.node)
42
+ }
43
+ </script>
44
+
45
+ <template>
46
+ <div class="node-box">
47
+ <!-- <div class="end-node-circle"></div>-->
48
+ <el-flex class="start-node" @click="activeNode" align="center">
49
+ <el-icons model-value="adtec-start" size="30"></el-icons>
50
+ <!-- <el-text>流程开启</el-text>-->
51
+ </el-flex>
52
+ <Add @add-node="addNode" />
53
+ </div>
54
+ </template>
55
+
56
+ <style scoped lang="scss">
57
+ .node-box {
58
+ position: relative;
59
+ padding-bottom: 0;
60
+ padding-top: 40px;
61
+ //.end-node-circle {
62
+ // width: 10px;
63
+ // height: 10px;
64
+ // border-radius: 50%;
65
+ // background-color: var(--el-border-color);
66
+ // margin: auto auto 5px;
67
+ //}
68
+
69
+ .start-node {
70
+ position: relative;
71
+ background: white; //var(--el-border-color-lighter);
72
+ padding: 6px;
73
+ border-radius: 24px;
74
+ cursor: pointer;
75
+ overflow: visible;
76
+ z-index: 10;
77
+ box-shadow: var(--el-box-shadow-light);
78
+ color: v-bind(iconColor); //#0b83de; //#18ad43;
79
+ &:hover {
80
+ box-shadow: 0 0 5px 0 var(--el-color-primary);
81
+ }
82
+ }
83
+ }
84
+ </style>