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,263 +1,264 @@
1
- <!--创建人 丁盼-->
2
- <!--说明: ElTableColumnTable-->
3
- <!--创建时间: 2024/11/27 上午11:56-->
4
- <!--修改时间: 2024/11/27 上午11:56-->
5
- <template>
6
- <div
7
- @click.stop.prevent="displayClick"
8
- style="width: 100%; min-height: 35px;cursor: pointer;display: flex;align-items: center;"
9
- ref="ref_divView"
10
- :id="guid"
11
- :class="getClass" >
12
- <!-- <FocusLock v-if="display" :no-focus-guards="false" class="foucs-lock">-->
13
- <!-- <slot name="edit" v-if="display" tabindex="9"></slot>-->
14
- <!-- </FocusLock>-->
15
- <slot name="edit" v-if="display" tabindex="9"></slot>
16
- <slot v-else name="view"></slot>
17
- </div>
18
- <div class="box" v-if="required" v-show="getRequiredComp"></div>
19
- </template>
20
- <script setup lang="ts">
21
- import { computed, getCurrentInstance, nextTick, onMounted, onUnmounted, ref, watch } from 'vue'
22
- import { useActiveElement, useEventBus, useFocus, watchPausable } from '@vueuse/core'
23
- // import FocusLock from 'vue-focus-lock'
24
- const ref_divView = ref()
25
- import { v4 as uuidv4 } from 'uuid'
26
- // const { focused } = useFocusWithin(ref_divView)
27
- const { focused: paragraphFocus } = useFocus(ref_divView)
28
- const display = ref(false)
29
- const guid = uuidv4()
30
- const bus = useEventBus<string>('elTableColumnEdit')
31
- const bus1 = useEventBus<string>(guid)
32
- const busDisplayClick = useEventBus<string>(guid + 'displayClick')
33
- // const props = defineProps<{
34
- // tableRef: any
35
- // }>()
36
- const getRequiredComp = computed(() => {
37
- if (props.scope?.row[props.scope.column.property]) {
38
- return false
39
- } else {
40
- return true
41
- }
42
- })
43
- const activeElement = useActiveElement()
44
- watch(activeElement, (el: any) => {
45
- // //判断当前点击元素是否在表格范围内
46
- if (props.isEdit) {
47
- let el1: any = el
48
- let b = true
49
- let c = false
50
- let f = true
51
- while (b) {
52
- if (el1.className?.indexOf('el-table') > -1) {
53
- c = true
54
- b = false
55
- } else if (el1.className?.indexOf('el-popper') > -1) {
56
- b = false
57
- f = false
58
- } else {
59
- el1 = el1.parentNode
60
- if (el1 === null) {
61
- b = false
62
- }
63
- }
64
- }
65
- if (f) {
66
- if (!c) {
67
- paragraphFocus.value = false
68
- display.value = false
69
- } else {
70
- //判断当前点击元素ID 是否是当前组件ID
71
- let el2: any = el
72
- let d = true
73
- let e = false
74
- while (d) {
75
- if (el2.id === guid) {
76
- d = false
77
- e = true
78
- } else {
79
- el2 = el2.parentNode
80
- if (el2 === null) {
81
- d = false
82
- }
83
- }
84
- }
85
- if (e) {
86
- display.value = true
87
- } else {
88
- display.value = false
89
- }
90
- }
91
- }
92
- }
93
- })
94
- const instance = getCurrentInstance()
95
- const table = ref()
96
- const showOverflowTooltip = ref(false)
97
- const oldValue = ref()
98
- const props = withDefaults(
99
- defineProps<{
100
- scope?: any
101
- /**
102
- * @type boolean
103
- * @default ''
104
- * @description 设置是否记录编辑状态,默认为false
105
- */
106
- enableEditingStatus?: boolean
107
- isEdit?: boolean
108
- required?: boolean
109
- }>(),
110
- {
111
- /**
112
- * @type string
113
- * @default ''
114
- * @description 设置是否记录编辑状态,默认为falseenableEditingStatus
115
- */
116
- enableEditingStatus: false,
117
- isEdit: true,
118
- required: false,
119
- },
120
- )
121
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
122
- const { stop, pause, resume } = watchPausable(
123
- () => props.scope?.row[props.scope.column.property],
124
- (v) => {
125
- let val
126
- if (oldValue.value === undefined || oldValue.value === null) {
127
- val = ''
128
- } else {
129
- val = oldValue.value + ''
130
- }
131
- if (v + '' !== val) {
132
- if (!props.scope.row.isRowEditArr) {
133
- // eslint-disable-next-line vue/no-mutating-props
134
- props.scope.row.isRowEditArr = []
135
- }
136
- if (props.scope.row.isRowEditArr.indexOf(props.scope.column.property) === -1) {
137
- // eslint-disable-next-line vue/no-mutating-props
138
- props.scope.row.isRowEditArr.push(props.scope.column.property)
139
- }
140
- } else {
141
- if (props.scope.row.isRowEditArr) {
142
- // eslint-disable-next-line vue/no-mutating-props
143
- props.scope.row.isRowEditArr.splice(
144
- props.scope.row.isRowEditArr.indexOf(props.scope.column.property),
145
- 1,
146
- )
147
- }
148
- }
149
- if (props.scope.row.isRowEditArr && props.scope.row.isRowEditArr.length > 0) {
150
- // eslint-disable-next-line vue/no-mutating-props
151
- props.scope.row.isRowEdit = true
152
- } else {
153
- // eslint-disable-next-line vue/no-mutating-props
154
- props.scope.row.isRowEdit = false
155
- }
156
- },
157
- )
158
- pause()
159
- onMounted(() => {
160
- // if (props.enableEditingStatus) {
161
- // resume()
162
- // } else {
163
- // pause()
164
- // }
165
- if (props.scope) {
166
- oldValue.value = props.scope.row[props.scope.column.property]
167
- }
168
- // props.scope.column.property.required = props.required
169
- let b = true
170
- let instance1: any = instance
171
- while (b) {
172
- if (instance1?.type?.name === 'ElTable' || instance1?.type?.__name === 'ElTable') {
173
- b = false
174
- } else {
175
- instance1 = instance1?.parent
176
- if (instance1 === null) {
177
- b = false
178
- }
179
- }
180
- }
181
- table.value = instance1
182
- showOverflowTooltip.value = table.value?.props?.showOverflowTooltip
183
- busDisplayClick.on(displayClick)
184
- })
185
- onUnmounted(() => {
186
- bus.off(listener)
187
- bus1.off(listener)
188
- busDisplayClick.off(displayClick)
189
- })
190
- const getClass = computed(() => {
191
- let className = showOverflowTooltip.value ? 'showOverflowTooltip' : ''
192
- if (props.isEdit) {
193
- return (className += ' el-table-column-edit')
194
- } else {
195
- return (className += ' el-table-column-view')
196
- }
197
- })
198
- function listener() {
199
- display.value = false
200
- bus.off(listener)
201
- bus1.off(listener)
202
- }
203
- const displayClick = () => {
204
- if (props.isEdit) {
205
- bus.emit()
206
- bus.on(listener)
207
- bus1.on(listener)
208
- resume()
209
- display.value = true
210
- nextTick(()=>{
211
- ref_divView.value.querySelector('input')?.focus()
212
- })
213
- }
214
- }
215
- </script>
216
- <style scoped lang="scss">
217
- .showOverflowTooltip {
218
- white-space: nowrap;
219
- overflow: hidden;
220
- text-overflow: ellipsis;
221
- }
222
- .foucs-lock {
223
- :deep {
224
- div[data-lock=''] {
225
- display: flex;
226
- margin-top: 1.5px;
227
- }
228
- }
229
- }
230
- //.box ~ .parent {
231
- // background-color: blue;
232
- //}
233
-
234
- .box {
235
- position: absolute;
236
- top: 0;
237
- right: 0;
238
- //width: 5px;
239
- //height: 5px;
240
- }
241
- /* 创建三角形 */
242
- .box::after {
243
- content: '';
244
- position: absolute;
245
- top: 0;
246
- right: 0;
247
- border-width: 0 5px 0px 0;
248
- border-style: solid;
249
- border-color: transparent;
250
- z-index: 1;
251
- }
252
-
253
- /* 创建三角形的边框 */
254
- .box::before {
255
- content: '';
256
- position: absolute;
257
- top: 0;
258
- right: 0;
259
- border-width: 0 5px 5px 0;
260
- border-style: solid;
261
- border-color: transparent #ff0000 transparent transparent;
262
- }
263
- </style>
1
+ <!--创建人 丁盼-->
2
+ <!--说明: ElTableColumnTable-->
3
+ <!--创建时间: 2024/11/27 上午11:56-->
4
+ <!--修改时间: 2024/11/27 上午11:56-->
5
+ <template>
6
+ <div
7
+ @click.stop.prevent="displayClick"
8
+ style="width: 100%; min-height: 35px"
9
+ ref="ref_divView"
10
+ :id="guid"
11
+ :class="getClass"
12
+ tabindex="0">
13
+ <FocusLock v-if="display" :no-focus-guards="false" class="foucs-lock">
14
+ <slot name="edit" v-if="display" tabindex="9"></slot>
15
+ </FocusLock>
16
+ <slot v-else name="view"></slot>
17
+ </div>
18
+ <div class="box" v-if="required" v-show="getRequiredComp"></div>
19
+ </template>
20
+ <script setup lang="ts">
21
+ import { computed, getCurrentInstance, nextTick, onMounted, onUnmounted, ref, watch } from 'vue'
22
+ import { useActiveElement, useEventBus, useFocus, watchPausable } from '@vueuse/core'
23
+ import FocusLock from 'vue-focus-lock'
24
+ const ref_divView = ref()
25
+ import { v4 as uuidv4 } from 'uuid'
26
+ // const { focused } = useFocusWithin(ref_divView)
27
+ const { focused: paragraphFocus } = useFocus(ref_divView)
28
+ const display = ref(false)
29
+ const guid = uuidv4()
30
+ const bus = useEventBus<string>('elTableColumnEdit')
31
+ const bus1 = useEventBus<string>(guid)
32
+ const busDisplayClick = useEventBus<string>(guid + 'displayClick')
33
+ // const props = defineProps<{
34
+ // tableRef: any
35
+ // }>()
36
+ const getRequiredComp = computed(() => {
37
+ if (props.scope?.row[props.scope.column.property]) {
38
+ return false
39
+ } else {
40
+ return true
41
+ }
42
+ })
43
+ const activeElement = useActiveElement()
44
+ watch(activeElement, (el: any) => {
45
+ // //判断当前点击元素是否在表格范围内
46
+ if (props.isEdit) {
47
+ let el1: any = el
48
+ let b = true
49
+ let c = false
50
+ let f = true
51
+ while (b) {
52
+ if (el1.className?.indexOf('el-table') > -1) {
53
+ c = true
54
+ b = false
55
+ } else if (el1.className?.indexOf('el-popper') > -1) {
56
+ b = false
57
+ f = false
58
+ } else {
59
+ el1 = el1.parentNode
60
+ if (el1 === null) {
61
+ b = false
62
+ }
63
+ }
64
+ }
65
+ if (f) {
66
+ if (!c) {
67
+ paragraphFocus.value = false
68
+ display.value = false
69
+ } else {
70
+ //判断当前点击元素ID 是否是当前组件ID
71
+ let el2: any = el
72
+ let d = true
73
+ let e = false
74
+ while (d) {
75
+ if (el2.id === guid) {
76
+ d = false
77
+ e = true
78
+ } else {
79
+ el2 = el2.parentNode
80
+ if (el2 === null) {
81
+ d = false
82
+ }
83
+ }
84
+ }
85
+ if (e) {
86
+ display.value = true
87
+ } else {
88
+ display.value = false
89
+ }
90
+ }
91
+ }
92
+ }
93
+ })
94
+ const instance = getCurrentInstance()
95
+ const table = ref()
96
+ const showOverflowTooltip = ref(false)
97
+ const oldValue = ref()
98
+ const props = withDefaults(
99
+ defineProps<{
100
+ scope?: any
101
+ /**
102
+ * @type boolean
103
+ * @default ''
104
+ * @description 设置是否记录编辑状态,默认为false
105
+ */
106
+ enableEditingStatus?: boolean
107
+ isEdit?: boolean
108
+ required?: boolean
109
+ }>(),
110
+ {
111
+ /**
112
+ * @type string
113
+ * @default ''
114
+ * @description 设置是否记录编辑状态,默认为falseenableEditingStatus
115
+ */
116
+ enableEditingStatus: false,
117
+ isEdit: true,
118
+ required: false,
119
+ },
120
+ )
121
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
122
+ const { stop, pause, resume } = watchPausable(
123
+ () => props.scope?.row[props.scope.column.property],
124
+ (v) => {
125
+ let val
126
+ if (oldValue.value === undefined || oldValue.value === null) {
127
+ val = ''
128
+ } else {
129
+ val = oldValue.value + ''
130
+ }
131
+ if (v + '' !== val) {
132
+ if (!props.scope.row.isRowEditArr) {
133
+ // eslint-disable-next-line vue/no-mutating-props
134
+ props.scope.row.isRowEditArr = []
135
+ }
136
+ if (props.scope.row.isRowEditArr.indexOf(props.scope.column.property) === -1) {
137
+ // eslint-disable-next-line vue/no-mutating-props
138
+ props.scope.row.isRowEditArr.push(props.scope.column.property)
139
+ }
140
+ } else {
141
+ if (props.scope.row.isRowEditArr) {
142
+ // eslint-disable-next-line vue/no-mutating-props
143
+ props.scope.row.isRowEditArr.splice(
144
+ props.scope.row.isRowEditArr.indexOf(props.scope.column.property),
145
+ 1,
146
+ )
147
+ }
148
+ }
149
+ if (props.scope.row.isRowEditArr && props.scope.row.isRowEditArr.length > 0) {
150
+ // eslint-disable-next-line vue/no-mutating-props
151
+ props.scope.row.isRowEdit = true
152
+ } else {
153
+ // eslint-disable-next-line vue/no-mutating-props
154
+ props.scope.row.isRowEdit = false
155
+ }
156
+ },
157
+ )
158
+ pause()
159
+ onMounted(() => {
160
+ // if (props.enableEditingStatus) {
161
+ // resume()
162
+ // } else {
163
+ // pause()
164
+ // }
165
+ if (props.scope) {
166
+ oldValue.value = props.scope.row[props.scope.column.property]
167
+ }
168
+ // props.scope.column.property.required = props.required
169
+ let b = true
170
+ let instance1: any = instance
171
+ while (b) {
172
+ if (instance1?.type?.name === 'ElTable' || instance1?.type?.__name === 'ElTable') {
173
+ b = false
174
+ } else {
175
+ instance1 = instance1?.parent
176
+ if (instance1 === null) {
177
+ b = false
178
+ }
179
+ }
180
+ }
181
+ table.value = instance1
182
+ showOverflowTooltip.value = table.value?.props?.showOverflowTooltip
183
+ busDisplayClick.on(displayClick)
184
+ })
185
+ onUnmounted(() => {
186
+ bus.off(listener)
187
+ bus1.off(listener)
188
+ busDisplayClick.off(displayClick)
189
+ })
190
+ const getClass = computed(() => {
191
+ let className = showOverflowTooltip.value ? 'showOverflowTooltip' : ''
192
+ if (props.isEdit) {
193
+ return (className += ' el-table-column-edit')
194
+ } else {
195
+ return (className += ' el-table-column-view')
196
+ }
197
+ })
198
+ function listener() {
199
+ display.value = false
200
+ bus.off(listener)
201
+ bus1.off(listener)
202
+ }
203
+ const displayClick = () => {
204
+ if (props.isEdit) {
205
+ bus.emit()
206
+ console.log(guid)
207
+ bus.on(listener)
208
+ bus1.on(listener)
209
+ resume()
210
+ display.value = true
211
+ nextTick(() => {
212
+ display.value = true
213
+ })
214
+ }
215
+ }
216
+ </script>
217
+ <style scoped lang="scss">
218
+ .showOverflowTooltip {
219
+ white-space: nowrap;
220
+ overflow: hidden;
221
+ text-overflow: ellipsis;
222
+ }
223
+ .foucs-lock {
224
+ :deep {
225
+ div[data-lock=''] {
226
+ display: flex;
227
+ margin-top: 1.5px;
228
+ }
229
+ }
230
+ }
231
+ //.box ~ .parent {
232
+ // background-color: blue;
233
+ //}
234
+
235
+ .box {
236
+ position: absolute;
237
+ top: 0;
238
+ right: 0;
239
+ //width: 5px;
240
+ //height: 5px;
241
+ }
242
+ /* 创建三角形 */
243
+ .box::after {
244
+ content: '';
245
+ position: absolute;
246
+ top: 0;
247
+ right: 0;
248
+ border-width: 0 5px 0px 0;
249
+ border-style: solid;
250
+ border-color: transparent;
251
+ z-index: 1;
252
+ }
253
+
254
+ /* 创建三角形的边框 */
255
+ .box::before {
256
+ content: '';
257
+ position: absolute;
258
+ top: 0;
259
+ right: 0;
260
+ border-width: 0 5px 5px 0;
261
+ border-style: solid;
262
+ border-color: transparent #ff0000 transparent transparent;
263
+ }
264
+ </style>
@@ -1,37 +1,37 @@
1
- import { ElMessage } from 'element-plus'
2
-
3
- /**
4
- * Create by丁盼
5
- * 说明: tableTool
6
- * 创建时间: 2025/2/28 09:42
7
- * 修改时间: 2025/2/28 09:42
8
- */
9
- export default {
10
- /**
11
- * 校验表格数据是否为空
12
- * @param table 表格对象
13
- * @param rules 校验规则
14
- */
15
- validateTableData(table: any,rules:any): Boolean {
16
- try {
17
- const data=table.value?table.value.data:table.data
18
- data.forEach((row: any,index:number) => {
19
- for(let v in rules){
20
- if (!row[v]) {
21
- let msg=rules[v].message
22
- if(msg){
23
- msg=msg.replace('{index}',index+1)
24
- }
25
- throw new Error(msg)
26
- }
27
- }
28
- })
29
- return true
30
- } catch (e:any) {
31
- if(e.message) {
32
- ElMessage.warning(e.message)
33
- }
34
- return false
35
- }
36
- },
37
- }
1
+ import { ElMessage } from 'element-plus'
2
+
3
+ /**
4
+ * Create by丁盼
5
+ * 说明: tableTool
6
+ * 创建时间: 2025/2/28 09:42
7
+ * 修改时间: 2025/2/28 09:42
8
+ */
9
+ export default {
10
+ /**
11
+ * 校验表格数据是否为空
12
+ * @param table 表格对象
13
+ * @param rules 校验规则
14
+ */
15
+ validateTableData(table: any,rules:any): Boolean {
16
+ try {
17
+ const data=table.value?table.value.data:table.data
18
+ data.forEach((row: any,index:number) => {
19
+ for(let v in rules){
20
+ if (!row[v]) {
21
+ let msg=rules[v].message
22
+ if(msg){
23
+ msg=msg.replace('{index}',index+1)
24
+ }
25
+ throw new Error(msg)
26
+ }
27
+ }
28
+ })
29
+ return true
30
+ } catch (e:any) {
31
+ if(e.message) {
32
+ ElMessage.warning(e.message)
33
+ }
34
+ return false
35
+ }
36
+ },
37
+ }