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,264 +1,264 @@
1
- <script setup lang="ts">
2
- import { useVModel } from '@vueuse/core'
3
- import type { TreeNodeData } from 'element-plus/es/components/tree/src/tree.type'
4
- import { ElMessage, type ElTree } from 'element-plus'
5
- import { getList } from '../../api/modules/role'
6
- import { Check } from '@element-plus/icons-vue'
7
- import { reactive, ref, watch } from 'vue'
8
- import frameworkUtils from '../../../../utils/FrameworkUtils.ts'
9
-
10
- export type ModelValueType = string | string[] | null | undefined
11
-
12
- export interface RoleDropdownProps {
13
- modelValue: ModelValueType
14
- multiple?: boolean
15
- }
16
-
17
- const treeProps = {
18
- label: 'name',
19
- children: 'children',
20
- isLeaf: 'leaf',
21
- class: (role: TreeNodeData) => renderClass(role),
22
- }
23
-
24
- export interface Role {
25
- id: string
26
- name: string
27
- }
28
-
29
- const $props = withDefaults(defineProps<RoleDropdownProps>(), {
30
- multiple: false,
31
- })
32
-
33
- const $emits = defineEmits<{
34
- (e: 'update:modelValue', modelValue: ModelValueType): void
35
- }>()
36
-
37
- const value = useVModel($props, 'modelValue', $emits)
38
-
39
- const roleOptions = ref<Role[]>([])
40
- const roleOrgOptions = ref<Role[]>([])
41
- const orgTreeRef = ref<InstanceType<typeof ElTree>>()
42
- const expandedKeys = ref<string[]>([])
43
-
44
- const renderClass = (role: TreeNodeData): string | { [key: string]: boolean } => {
45
- const val = roleOptions.value.find((e) => e.id === role.id)
46
- if (val) {
47
- return 'is-active'
48
- } else {
49
- return ''
50
- }
51
- }
52
-
53
- const onNodeClick = (data: Role) => {
54
- if ($props.multiple) {
55
- const index = roleOptions.value.findIndex((e) => e.id === data.id)
56
- if (index === -1) {
57
- roleOptions.value.push(data)
58
- roleOptions.value.sort((a, b) => a.id.localeCompare(b.id))
59
- } else {
60
- roleOptions.value.splice(index, 1)
61
- }
62
- } else {
63
- const index = roleOptions.value.findIndex((e) => e.id === data.id)
64
- if (index === -1) {
65
- roleOptions.value = [data]
66
- } else {
67
- roleOptions.value.splice(index, 1)
68
- }
69
- }
70
- }
71
- const dialogVisible = ref(false)
72
- const queryForm = reactive({
73
- name: null,
74
- })
75
-
76
- watch(
77
- () => queryForm.name,
78
- (val) => {
79
- orgTreeRef.value?.filter(val)
80
- },
81
- )
82
- const filterNode = (value: string, data: TreeNodeData): boolean => {
83
- if (!value) return true
84
- return data.name.includes(value)
85
- }
86
- const open = () => {
87
- dialogVisible.value = true
88
- }
89
- const onOpen = async () => {
90
- // getList().then((res) => {
91
- // if (res.records) {
92
- // roleOrgOptions.value = res.records.map((e) => {
93
- // return {
94
- // id: e.roleId,
95
- // name: e.roleName
96
- // } as Role
97
- // })
98
- // }
99
- // })
100
- roleOptions.value = []
101
- queryForm.name = null
102
- try {
103
- const res = await getList()
104
- roleOrgOptions.value = res.map((e) => {
105
- return {
106
- id: e.id,
107
- name: e.name,
108
- } as Role
109
- })
110
- let roleIds: string[] = []
111
- if (Array.isArray(value.value)) {
112
- roleIds.push(...value.value)
113
- } else if (value.value) {
114
- roleIds.push(value.value)
115
- }
116
- if (roleIds.length > 0) {
117
- roleOrgOptions.value.forEach((e) => {
118
- if (roleIds.indexOf(e.id) > -1) {
119
- roleOptions.value.push(e)
120
- }
121
- })
122
- } else {
123
- roleOptions.value = []
124
- }
125
- } catch (err: any) {
126
- frameworkUtils.messageError(err)
127
- }
128
- // let roleIds: string[] = []
129
- // if (Array.isArray(value.value)) {
130
- // roleIds.push(...value.value)
131
- // } else if (value.value) {
132
- // roleIds.push(value.value)
133
- // }
134
- // if (roleIds.length > 0) {
135
- // getRoleListById(roleIds).then((res) => {
136
- // if (res.records) {
137
- // roleOptions.value = res.map((role) => {
138
- // return {
139
- // id: role.roleId,
140
- // name: role.roleName
141
- // } as Role
142
- // })
143
- // roleOptions.value.sort((a, b) => a.id.localeCompare(b.id))
144
- // }
145
- // })
146
- // } else {
147
- // roleOptions.value = []
148
- // }
149
- }
150
- const handelConfirm = () => {
151
- if ($props.multiple) {
152
- value.value = roleOptions.value.map((e) => e.id)
153
- } else {
154
- if (roleOptions.value.length > 0) {
155
- value.value = roleOptions.value[0].id
156
- } else {
157
- value.value = null
158
- }
159
- }
160
- dialogVisible.value = false
161
- }
162
- defineExpose({
163
- open,
164
- })
165
- </script>
166
-
167
- <template>
168
- <el-dialog
169
- v-model="dialogVisible"
170
- @open="onOpen"
171
- align-center
172
- draggable
173
- title="选择角色"
174
- width="30%"
175
- >
176
- <el-card shadow="never" class="org-card">
177
- <template #header>
178
- <el-input
179
- v-model="queryForm.name"
180
- placeholder="输入关键字进行查询"
181
- :style="{ width: '100%' }"
182
- suffix-icon="search"
183
- clearable
184
- >
185
- </el-input>
186
- </template>
187
- <el-scrollbar tag="div" class="org-tree">
188
- <el-tree
189
- ref="orgTreeRef"
190
- node-key="id"
191
- :data="roleOrgOptions"
192
- :default-expanded-keys="expandedKeys"
193
- :props="treeProps"
194
- :filter-node-method="filterNode"
195
- @node-click="onNodeClick"
196
- >
197
- <template #default="{ data }">
198
- <!-- <div class="flex flex-1 flex-items-center flex-justify-between">-->
199
- <!-- <div class="flex-center">&nbsp;{{ data.name }}</div>-->
200
- <!-- <el-icon class="is-selected">-->
201
- <!-- <Check />-->
202
- <!-- </el-icon>-->
203
- <!-- </div>-->
204
- <el-row justify="space-between" align="middle" style="width: 100%">
205
- <div>
206
- {{ data.name }}
207
- </div>
208
- <el-icon class="is-selected">
209
- <Check />
210
- </el-icon>
211
- </el-row>
212
- </template>
213
- </el-tree>
214
- </el-scrollbar>
215
- </el-card>
216
- <template #footer>
217
- <el-button @click="dialogVisible = false">取消</el-button>
218
- <el-button type="primary" @click="handelConfirm">确认</el-button>
219
- </template>
220
- </el-dialog>
221
- </template>
222
-
223
- <style scoped lang="scss">
224
- :deep {
225
- .el-tree {
226
- --el-tree-node-content-height: 40px;
227
-
228
- .el-tree-node__content {
229
- border-radius: 8px;
230
- margin: 2px 0 2px 0;
231
- }
232
-
233
- .is-active {
234
- color: var(--el-color-primary);
235
-
236
- .is-selected {
237
- display: block;
238
- }
239
- }
240
- }
241
- }
242
-
243
- .el-card {
244
- background-color: transparent;
245
-
246
- :deep(.el-card__header) {
247
- padding: 10px !important;
248
- }
249
-
250
- :deep(.el-card__body) {
251
- padding: 0 !important;
252
- }
253
- }
254
-
255
- .org-tree {
256
- height: 270px;
257
- padding: 5px;
258
- }
259
-
260
- .is-selected {
261
- display: none;
262
- padding-right: 15px;
263
- }
264
- </style>
1
+ <script setup lang="ts">
2
+ import { useVModel } from '@vueuse/core'
3
+ import type { TreeNodeData } from 'element-plus/es/components/tree/src/tree.type'
4
+ import { ElMessage, type ElTree } from 'element-plus'
5
+ import { getList } from '../../api/modules/role'
6
+ import { Check } from '@element-plus/icons-vue'
7
+ import { reactive, ref, watch } from 'vue'
8
+ import frameworkUtils from '../../../../utils/FrameworkUtils.ts'
9
+
10
+ export type ModelValueType = string | string[] | null | undefined
11
+
12
+ export interface RoleDropdownProps {
13
+ modelValue: ModelValueType
14
+ multiple?: boolean
15
+ }
16
+
17
+ const treeProps = {
18
+ label: 'name',
19
+ children: 'children',
20
+ isLeaf: 'leaf',
21
+ class: (role: TreeNodeData) => renderClass(role),
22
+ }
23
+
24
+ export interface Role {
25
+ id: string
26
+ name: string
27
+ }
28
+
29
+ const $props = withDefaults(defineProps<RoleDropdownProps>(), {
30
+ multiple: false,
31
+ })
32
+
33
+ const $emits = defineEmits<{
34
+ (e: 'update:modelValue', modelValue: ModelValueType): void
35
+ }>()
36
+
37
+ const value = useVModel($props, 'modelValue', $emits)
38
+
39
+ const roleOptions = ref<Role[]>([])
40
+ const roleOrgOptions = ref<Role[]>([])
41
+ const orgTreeRef = ref<InstanceType<typeof ElTree>>()
42
+ const expandedKeys = ref<string[]>([])
43
+
44
+ const renderClass = (role: TreeNodeData): string | { [key: string]: boolean } => {
45
+ const val = roleOptions.value.find((e) => e.id === role.id)
46
+ if (val) {
47
+ return 'is-active'
48
+ } else {
49
+ return ''
50
+ }
51
+ }
52
+
53
+ const onNodeClick = (data: Role) => {
54
+ if ($props.multiple) {
55
+ const index = roleOptions.value.findIndex((e) => e.id === data.id)
56
+ if (index === -1) {
57
+ roleOptions.value.push(data)
58
+ roleOptions.value.sort((a, b) => a.id.localeCompare(b.id))
59
+ } else {
60
+ roleOptions.value.splice(index, 1)
61
+ }
62
+ } else {
63
+ const index = roleOptions.value.findIndex((e) => e.id === data.id)
64
+ if (index === -1) {
65
+ roleOptions.value = [data]
66
+ } else {
67
+ roleOptions.value.splice(index, 1)
68
+ }
69
+ }
70
+ }
71
+ const dialogVisible = ref(false)
72
+ const queryForm = reactive({
73
+ name: null,
74
+ })
75
+
76
+ watch(
77
+ () => queryForm.name,
78
+ (val) => {
79
+ orgTreeRef.value?.filter(val)
80
+ },
81
+ )
82
+ const filterNode = (value: string, data: TreeNodeData): boolean => {
83
+ if (!value) return true
84
+ return data.name.includes(value)
85
+ }
86
+ const open = () => {
87
+ dialogVisible.value = true
88
+ }
89
+ const onOpen = async () => {
90
+ // getList().then((res) => {
91
+ // if (res.records) {
92
+ // roleOrgOptions.value = res.records.map((e) => {
93
+ // return {
94
+ // id: e.roleId,
95
+ // name: e.roleName
96
+ // } as Role
97
+ // })
98
+ // }
99
+ // })
100
+ roleOptions.value = []
101
+ queryForm.name = null
102
+ try {
103
+ const res = await getList()
104
+ roleOrgOptions.value = res.map((e) => {
105
+ return {
106
+ id: e.id,
107
+ name: e.name,
108
+ } as Role
109
+ })
110
+ let roleIds: string[] = []
111
+ if (Array.isArray(value.value)) {
112
+ roleIds.push(...value.value)
113
+ } else if (value.value) {
114
+ roleIds.push(value.value)
115
+ }
116
+ if (roleIds.length > 0) {
117
+ roleOrgOptions.value.forEach((e) => {
118
+ if (roleIds.indexOf(e.id) > -1) {
119
+ roleOptions.value.push(e)
120
+ }
121
+ })
122
+ } else {
123
+ roleOptions.value = []
124
+ }
125
+ } catch (err: any) {
126
+ frameworkUtils.messageError(err)
127
+ }
128
+ // let roleIds: string[] = []
129
+ // if (Array.isArray(value.value)) {
130
+ // roleIds.push(...value.value)
131
+ // } else if (value.value) {
132
+ // roleIds.push(value.value)
133
+ // }
134
+ // if (roleIds.length > 0) {
135
+ // getRoleListById(roleIds).then((res) => {
136
+ // if (res.records) {
137
+ // roleOptions.value = res.map((role) => {
138
+ // return {
139
+ // id: role.roleId,
140
+ // name: role.roleName
141
+ // } as Role
142
+ // })
143
+ // roleOptions.value.sort((a, b) => a.id.localeCompare(b.id))
144
+ // }
145
+ // })
146
+ // } else {
147
+ // roleOptions.value = []
148
+ // }
149
+ }
150
+ const handelConfirm = () => {
151
+ if ($props.multiple) {
152
+ value.value = roleOptions.value.map((e) => e.id)
153
+ } else {
154
+ if (roleOptions.value.length > 0) {
155
+ value.value = roleOptions.value[0].id
156
+ } else {
157
+ value.value = null
158
+ }
159
+ }
160
+ dialogVisible.value = false
161
+ }
162
+ defineExpose({
163
+ open,
164
+ })
165
+ </script>
166
+
167
+ <template>
168
+ <el-dialog
169
+ v-model="dialogVisible"
170
+ @open="onOpen"
171
+ align-center
172
+ draggable
173
+ title="选择角色"
174
+ width="30%"
175
+ >
176
+ <el-card shadow="never" class="org-card">
177
+ <template #header>
178
+ <el-input
179
+ v-model="queryForm.name"
180
+ placeholder="输入关键字进行查询"
181
+ :style="{ width: '100%' }"
182
+ suffix-icon="search"
183
+ clearable
184
+ >
185
+ </el-input>
186
+ </template>
187
+ <el-scrollbar tag="div" class="org-tree">
188
+ <el-tree
189
+ ref="orgTreeRef"
190
+ node-key="id"
191
+ :data="roleOrgOptions"
192
+ :default-expanded-keys="expandedKeys"
193
+ :props="treeProps"
194
+ :filter-node-method="filterNode"
195
+ @node-click="onNodeClick"
196
+ >
197
+ <template #default="{ data }">
198
+ <!-- <div class="flex flex-1 flex-items-center flex-justify-between">-->
199
+ <!-- <div class="flex-center">&nbsp;{{ data.name }}</div>-->
200
+ <!-- <el-icon class="is-selected">-->
201
+ <!-- <Check />-->
202
+ <!-- </el-icon>-->
203
+ <!-- </div>-->
204
+ <el-row justify="space-between" align="middle" style="width: 100%">
205
+ <div>
206
+ {{ data.name }}
207
+ </div>
208
+ <el-icon class="is-selected">
209
+ <Check />
210
+ </el-icon>
211
+ </el-row>
212
+ </template>
213
+ </el-tree>
214
+ </el-scrollbar>
215
+ </el-card>
216
+ <template #footer>
217
+ <el-button @click="dialogVisible = false">取消</el-button>
218
+ <el-button type="primary" @click="handelConfirm">确认</el-button>
219
+ </template>
220
+ </el-dialog>
221
+ </template>
222
+
223
+ <style scoped lang="scss">
224
+ :deep {
225
+ .el-tree {
226
+ --el-tree-node-content-height: 40px;
227
+
228
+ .el-tree-node__content {
229
+ border-radius: 8px;
230
+ margin: 2px 0 2px 0;
231
+ }
232
+
233
+ .is-active {
234
+ color: var(--el-color-primary);
235
+
236
+ .is-selected {
237
+ display: block;
238
+ }
239
+ }
240
+ }
241
+ }
242
+
243
+ .el-card {
244
+ background-color: transparent;
245
+
246
+ :deep(.el-card__header) {
247
+ padding: 10px !important;
248
+ }
249
+
250
+ :deep(.el-card__body) {
251
+ padding: 0 !important;
252
+ }
253
+ }
254
+
255
+ .org-tree {
256
+ height: 270px;
257
+ padding: 5px;
258
+ }
259
+
260
+ .is-selected {
261
+ display: none;
262
+ padding-right: 15px;
263
+ }
264
+ </style>
@@ -1,48 +1,48 @@
1
- <script setup lang="ts">
2
- import { onMounted } from 'vue'
3
-
4
- export interface RoleTagProps {
5
- id: string
6
- name: string
7
- type?: 'success' | 'info' | 'warning' | 'danger' | 'primary'
8
- closable?: boolean
9
- }
10
-
11
- const $props = withDefaults(defineProps<RoleTagProps>(), {
12
- closable: false,
13
- type: 'info',
14
- })
15
- const $emits = defineEmits<{
16
- (e: 'close', id: string): void
17
- }>()
18
-
19
- onMounted(() => {
20
- if (!$props.id || !$props.name) {
21
- throw new Error('role id/name is required')
22
- }
23
- // getById($props.id).then((res) => {
24
- // if (res.success) {
25
- // roleInfo.id = res.data.id
26
- // roleInfo.name = res.data.name
27
- // }
28
- // })
29
- })
30
- const onClose = () => {
31
- $emits('close', $props.id)
32
- }
33
- </script>
34
- <template>
35
- <el-tag round :closable="$props.closable" :type="type" effect="light" @close="onClose">
36
- <div class="flex-center" style="gap: 4px; grid-gap: 4px">
37
- <span>{{ name || id }}</span>
38
- </div>
39
- </el-tag>
40
- </template>
41
-
42
- <style scoped lang="scss">
43
- :deep {
44
- .el-tag__content:only-child {
45
- margin-right: 4px;
46
- }
47
- }
48
- </style>
1
+ <script setup lang="ts">
2
+ import { onMounted } from 'vue'
3
+
4
+ export interface RoleTagProps {
5
+ id: string
6
+ name: string
7
+ type?: 'success' | 'info' | 'warning' | 'danger' | 'primary'
8
+ closable?: boolean
9
+ }
10
+
11
+ const $props = withDefaults(defineProps<RoleTagProps>(), {
12
+ closable: false,
13
+ type: 'info',
14
+ })
15
+ const $emits = defineEmits<{
16
+ (e: 'close', id: string): void
17
+ }>()
18
+
19
+ onMounted(() => {
20
+ if (!$props.id || !$props.name) {
21
+ throw new Error('role id/name is required')
22
+ }
23
+ // getById($props.id).then((res) => {
24
+ // if (res.success) {
25
+ // roleInfo.id = res.data.id
26
+ // roleInfo.name = res.data.name
27
+ // }
28
+ // })
29
+ })
30
+ const onClose = () => {
31
+ $emits('close', $props.id)
32
+ }
33
+ </script>
34
+ <template>
35
+ <el-tag round :closable="$props.closable" :type="type" effect="light" @close="onClose">
36
+ <div class="flex-center" style="gap: 4px; grid-gap: 4px">
37
+ <span>{{ name || id }}</span>
38
+ </div>
39
+ </el-tag>
40
+ </template>
41
+
42
+ <style scoped lang="scss">
43
+ :deep {
44
+ .el-tag__content:only-child {
45
+ margin-right: 4px;
46
+ }
47
+ }
48
+ </style>