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,297 +1,297 @@
1
- <!--创建人 丁盼-->
2
- <!--说明: ElFlex-->
3
- <!--创建时间: 2024/9/5 下午3:15-->
4
- <!--修改时间: 2024/9/5 下午3:15-->
5
- <template>
6
- <div :style="getStyleComp" ref="ref_div">
7
- <slot />
8
- <div
9
- draggable="false"
10
- style="
11
- position: absolute;
12
- display: flex;
13
- align-items: center;
14
- cursor: pointer;
15
- user-select: none;
16
- "
17
- :style="{
18
- bottom: bottomComputed,
19
- right: rightComuted,
20
- }"
21
- ref="ref_div_resizable"
22
- @mousemove="handleMouseMove"
23
- v-if="resizable"
24
- >
25
- <el-icons
26
- v-if="parent?.props.vertical + '' === 'true'"
27
- model-value="adtec-upanddownpull"
28
- style="cursor: pointer; font-size: 32px; color: #cccccc"
29
- ></el-icons>
30
- <el-icons
31
- v-else
32
- model-value="adtec-aboutpull"
33
- style="cursor: pointer; font-size: 32px; color: #cccccc"
34
- ></el-icons>
35
- </div>
36
- </div>
37
- </template>
38
- <script setup lang="ts">
39
- import {
40
- alignItemsEnum,
41
- flexWrapEnum,
42
- gapEnum,
43
- justifyContentEnum,
44
- } from "../../interface/enum/FlexEnum.ts"
45
- import { computed, nextTick, onMounted, ref, watch, getCurrentInstance } from 'vue'
46
- import { useMousePressed } from '@vueuse/core'
47
- import ElIcons from '../icon/ElIcons.vue'
48
- const instance = getCurrentInstance()
49
- const parent = instance?.parent
50
- const ref_div = ref()
51
- const ref_div_resizable = ref()
52
- const { pressed } = useMousePressed({ target: ref_div_resizable })
53
- const divWidth = ref('')
54
- const divHeight = ref('')
55
- const bottomComputed = computed(() => {
56
- if (parent?.props.vertical + '' === 'true') {
57
- return '0px'
58
- } else {
59
- return '50%'
60
- }
61
- })
62
- const rightComuted = computed(() => {
63
- if (parent?.props.vertical + '' === 'true') {
64
- return '50%'
65
- } else {
66
- return '0px'
67
- }
68
- })
69
- watch(pressed, (val) => {
70
- if (!val) {
71
- document.onmousemove = null
72
- document.onmouseup = null
73
- }
74
- })
75
- const handleMouseMove = (e: any) => {
76
- if (pressed.value) {
77
- const disX = e.clientX - ref_div.value?.offsetLeft
78
- const disY = e.clientY - ref_div.value?.offsetTop
79
- const layoutWidth = ref_div.value?.clientWidth
80
- const layoutHeight = ref_div.value?.clientHeight
81
- document.onmousemove = (e) => {
82
- document.body.style.cursor = 'pointer'
83
- // 鼠标按下并移动的事件
84
- // 用鼠标的位置减去鼠标相对元素的位置,得到元素的位置
85
- const left = e.screenX - disX
86
- const top = e.clientY - disY
87
- if (parent?.props.vertical) {
88
- let after = layoutHeight + top
89
- after = after <= 8 ? 8 : after
90
- if (after < parseInt((props.minHeight + '').replace('px', ''))) {
91
- after = parseInt((props.minHeight + '').replace('px', ''))
92
- }
93
- nextTick(() => {
94
- divHeight.value = after + 'px'
95
- })
96
- } else {
97
- let after = layoutWidth + left
98
- after = after <= 8 ? 8 : after
99
- if (after < parseInt((props.minWidth + '').replace('px', ''))) {
100
- after = parseInt((props.minWidth + '').replace('px', ''))
101
- }
102
- nextTick(() => {
103
- divWidth.value = after + 'px'
104
- })
105
- }
106
- }
107
- document.onmouseup = () => {
108
- document.body.style.cursor = 'default'
109
- document.onmousemove = null
110
- document.onmouseup = null
111
- }
112
- }
113
- }
114
- const flexShrinkComp = computed(() => {
115
- return (divHeight.value + '').indexOf('px') > -1 || (divWidth.value + '').indexOf('px') > -1
116
- ? '0'
117
- : 'initial'
118
- // return (props.height+'').indexOf('px') > -1 || (props.width+'').indexOf('px') > -1 ? '0' : 'initial'
119
- })
120
- const heightComp = computed(() => {
121
- return divHeight.value
122
- })
123
- const widthComp = computed(() => {
124
- return divWidth.value
125
- })
126
- const getStyleComp = computed(() => {
127
- const style = {
128
- display: 'flex',
129
- flexDirection: verticalComputed.value ? 'column' : 'row',
130
- justifyContent: props.justify + '',
131
- alignItems: props.align + '',
132
- gap: props.gap + '',
133
- flexWrap: props.flexWrap + '',
134
- flexGrow: props.flexGrow ? props.flexGrow : 0,
135
- height: heightComp.value,
136
- width: widthComp.value,
137
- flex: getFlex(),
138
- overflow: 'auto',
139
- boxSizing: 'border-box',
140
- minWidth: props.minWidth ? props.minWidth : '',
141
- flexShrink: flexShrinkComp.value,
142
- }
143
- if (props.resizable) {
144
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
145
- //@ts-expect-error
146
- style.position = 'relative'
147
- }
148
- return style
149
- })
150
-
151
- const getFlex = () => {
152
- let v = '0 0'
153
- if ((widthComp.value + '').indexOf('px') > -1) {
154
- v += ' ' + widthComp.value
155
- } else {
156
- v += ' 0'
157
- }
158
- if ((heightComp.value + '').indexOf('px') > -1) {
159
- v += ' ' + heightComp.value
160
- } else {
161
- v += ' 0'
162
- }
163
- return v
164
- }
165
- onMounted(() => {
166
- divWidth.value = props.width ? props.width + '' : '100%'
167
- divHeight.value = props.height ? props.height + '' : '100%'
168
- })
169
- const verticalComputed = computed(() => {
170
- if (typeof props.vertical === 'string') {
171
- return Boolean(props.vertical)
172
- } else {
173
- return props.vertical
174
- }
175
- })
176
-
177
- const props = defineProps({
178
- /**
179
- * @type boolean|String
180
- * @default false
181
- * @description 横向布局
182
- */
183
- //@ts-ignore
184
- vertical: {
185
- type: [Boolean, String],
186
- default: false,
187
- },
188
- /**
189
- * @type {"flex-start" | "center" | "flex-end" | "space-between" | "space-around" | "space-evenly"}
190
- * @default 'flex-start'
191
- * @description 横向对齐方式
192
- */
193
- justify: {
194
- type: [justifyContentEnum, String],
195
- default: 'flex-start',
196
- validator: (value: string) =>
197
- [
198
- 'flex-start',
199
- 'center',
200
- 'flex-end',
201
- 'space-between',
202
- 'space-around',
203
- 'space-evenly',
204
- ].includes(value),
205
- },
206
- /**
207
- * @type {"flex-start" | "center" | "flex-end" }
208
- * @default 'flex-start'
209
- * @description 纵向对齐方式
210
- */
211
- align: {
212
- type: [alignItemsEnum, String],
213
- default: 'flex-start',
214
- validator: (value: string) => ['flex-start', 'center', 'flex-end'].includes(value),
215
- },
216
- /**
217
- * @type {"8px" | "16px" | "24px" }
218
- * @description 间距
219
- */
220
- gap: {
221
- type: [gapEnum, String],
222
- },
223
- /**
224
- * @type {"nowrap" | "wrap" | "wrap-reverse" }
225
- * @default 'nowrap'
226
- * @description 是否换行
227
- */
228
- flexWrap: {
229
- type: [flexWrapEnum, String],
230
- default: 'nowrap',
231
- validator: (value: string) => ['nowrap', 'wrap', 'wrap-reverse'].includes(value),
232
- },
233
- /**
234
- * @type
235
- * @default 0
236
- * @description 尺寸
237
- */
238
- flexGrow: {
239
- type: [Number, String],
240
- default: 0,
241
- },
242
- /**
243
- * @type
244
- * @default '100%'
245
- * @description 宽度
246
- */
247
- width: {
248
- type: [String],
249
- default: '100%',
250
- },
251
- /**
252
- * @type
253
- * @default '100%'
254
- * @description 高度
255
- */
256
- height: {
257
- type: [String],
258
- default: '100%',
259
- },
260
- /**
261
- * @type
262
- * @default ''
263
- * @description 最小宽度
264
- */
265
- minWidth: {
266
- type: [String],
267
- default: '',
268
- },
269
- /**
270
- * @type
271
- * @default ''
272
- * @description 最小高度
273
- */
274
- minHeigth: {
275
- type: [String],
276
- default: '',
277
- },
278
- /**
279
- * @type
280
- * @default false
281
- * @description 可拖拽
282
- */
283
- resizable: {
284
- type: [Boolean, String],
285
- default: false,
286
- },
287
- flexShrink: {
288
- type: [String],
289
- default: 'initial',
290
- },
291
- })
292
- watch(props, (val) => {
293
- divWidth.value = val.width + '' ? val.width + '' : '100%'
294
- divHeight.value = val.height + '' ? val.height + '' : '100%'
295
- })
296
- </script>
297
- <style scoped lang="scss"></style>
1
+ <!--创建人 丁盼-->
2
+ <!--说明: ElFlex-->
3
+ <!--创建时间: 2024/9/5 下午3:15-->
4
+ <!--修改时间: 2024/9/5 下午3:15-->
5
+ <template>
6
+ <div :style="getStyleComp" ref="ref_div">
7
+ <slot />
8
+ <div
9
+ draggable="false"
10
+ style="
11
+ position: absolute;
12
+ display: flex;
13
+ align-items: center;
14
+ cursor: pointer;
15
+ user-select: none;
16
+ "
17
+ :style="{
18
+ bottom: bottomComputed,
19
+ right: rightComuted,
20
+ }"
21
+ ref="ref_div_resizable"
22
+ @mousemove="handleMouseMove"
23
+ v-if="resizable"
24
+ >
25
+ <el-icons
26
+ v-if="parent?.props.vertical + '' === 'true'"
27
+ model-value="adtec-upanddownpull"
28
+ style="cursor: pointer; font-size: 32px; color: #cccccc"
29
+ ></el-icons>
30
+ <el-icons
31
+ v-else
32
+ model-value="adtec-aboutpull"
33
+ style="cursor: pointer; font-size: 32px; color: #cccccc"
34
+ ></el-icons>
35
+ </div>
36
+ </div>
37
+ </template>
38
+ <script setup lang="ts">
39
+ import {
40
+ alignItemsEnum,
41
+ flexWrapEnum,
42
+ gapEnum,
43
+ justifyContentEnum,
44
+ } from "../../interface/enum/FlexEnum.ts"
45
+ import { computed, nextTick, onMounted, ref, watch, getCurrentInstance } from 'vue'
46
+ import { useMousePressed } from '@vueuse/core'
47
+ import ElIcons from '../icon/ElIcons.vue'
48
+ const instance = getCurrentInstance()
49
+ const parent = instance?.parent
50
+ const ref_div = ref()
51
+ const ref_div_resizable = ref()
52
+ const { pressed } = useMousePressed({ target: ref_div_resizable })
53
+ const divWidth = ref('')
54
+ const divHeight = ref('')
55
+ const bottomComputed = computed(() => {
56
+ if (parent?.props.vertical + '' === 'true') {
57
+ return '0px'
58
+ } else {
59
+ return '50%'
60
+ }
61
+ })
62
+ const rightComuted = computed(() => {
63
+ if (parent?.props.vertical + '' === 'true') {
64
+ return '50%'
65
+ } else {
66
+ return '0px'
67
+ }
68
+ })
69
+ watch(pressed, (val) => {
70
+ if (!val) {
71
+ document.onmousemove = null
72
+ document.onmouseup = null
73
+ }
74
+ })
75
+ const handleMouseMove = (e: any) => {
76
+ if (pressed.value) {
77
+ const disX = e.clientX - ref_div.value?.offsetLeft
78
+ const disY = e.clientY - ref_div.value?.offsetTop
79
+ const layoutWidth = ref_div.value?.clientWidth
80
+ const layoutHeight = ref_div.value?.clientHeight
81
+ document.onmousemove = (e) => {
82
+ document.body.style.cursor = 'pointer'
83
+ // 鼠标按下并移动的事件
84
+ // 用鼠标的位置减去鼠标相对元素的位置,得到元素的位置
85
+ const left = e.screenX - disX
86
+ const top = e.clientY - disY
87
+ if (parent?.props.vertical) {
88
+ let after = layoutHeight + top
89
+ after = after <= 8 ? 8 : after
90
+ if (after < parseInt((props.minHeight + '').replace('px', ''))) {
91
+ after = parseInt((props.minHeight + '').replace('px', ''))
92
+ }
93
+ nextTick(() => {
94
+ divHeight.value = after + 'px'
95
+ })
96
+ } else {
97
+ let after = layoutWidth + left
98
+ after = after <= 8 ? 8 : after
99
+ if (after < parseInt((props.minWidth + '').replace('px', ''))) {
100
+ after = parseInt((props.minWidth + '').replace('px', ''))
101
+ }
102
+ nextTick(() => {
103
+ divWidth.value = after + 'px'
104
+ })
105
+ }
106
+ }
107
+ document.onmouseup = () => {
108
+ document.body.style.cursor = 'default'
109
+ document.onmousemove = null
110
+ document.onmouseup = null
111
+ }
112
+ }
113
+ }
114
+ const flexShrinkComp = computed(() => {
115
+ return (divHeight.value + '').indexOf('px') > -1 || (divWidth.value + '').indexOf('px') > -1
116
+ ? '0'
117
+ : 'initial'
118
+ // return (props.height+'').indexOf('px') > -1 || (props.width+'').indexOf('px') > -1 ? '0' : 'initial'
119
+ })
120
+ const heightComp = computed(() => {
121
+ return divHeight.value
122
+ })
123
+ const widthComp = computed(() => {
124
+ return divWidth.value
125
+ })
126
+ const getStyleComp = computed(() => {
127
+ const style = {
128
+ display: 'flex',
129
+ flexDirection: verticalComputed.value ? 'column' : 'row',
130
+ justifyContent: props.justify + '',
131
+ alignItems: props.align + '',
132
+ gap: props.gap + '',
133
+ flexWrap: props.flexWrap + '',
134
+ flexGrow: props.flexGrow ? props.flexGrow : 0,
135
+ height: heightComp.value,
136
+ width: widthComp.value,
137
+ flex: getFlex(),
138
+ overflow: 'auto',
139
+ boxSizing: 'border-box',
140
+ minWidth: props.minWidth ? props.minWidth : '',
141
+ flexShrink: flexShrinkComp.value,
142
+ }
143
+ if (props.resizable) {
144
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
145
+ //@ts-expect-error
146
+ style.position = 'relative'
147
+ }
148
+ return style
149
+ })
150
+
151
+ const getFlex = () => {
152
+ let v = '0 0'
153
+ if ((widthComp.value + '').indexOf('px') > -1) {
154
+ v += ' ' + widthComp.value
155
+ } else {
156
+ v += ' 0'
157
+ }
158
+ if ((heightComp.value + '').indexOf('px') > -1) {
159
+ v += ' ' + heightComp.value
160
+ } else {
161
+ v += ' 0'
162
+ }
163
+ return v
164
+ }
165
+ onMounted(() => {
166
+ divWidth.value = props.width ? props.width + '' : '100%'
167
+ divHeight.value = props.height ? props.height + '' : '100%'
168
+ })
169
+ const verticalComputed = computed(() => {
170
+ if (typeof props.vertical === 'string') {
171
+ return Boolean(props.vertical)
172
+ } else {
173
+ return props.vertical
174
+ }
175
+ })
176
+
177
+ const props = defineProps({
178
+ /**
179
+ * @type boolean|String
180
+ * @default false
181
+ * @description 横向布局
182
+ */
183
+ //@ts-ignore
184
+ vertical: {
185
+ type: [Boolean, String],
186
+ default: false,
187
+ },
188
+ /**
189
+ * @type {"flex-start" | "center" | "flex-end" | "space-between" | "space-around" | "space-evenly"}
190
+ * @default 'flex-start'
191
+ * @description 横向对齐方式
192
+ */
193
+ justify: {
194
+ type: [justifyContentEnum, String],
195
+ default: 'flex-start',
196
+ validator: (value: string) =>
197
+ [
198
+ 'flex-start',
199
+ 'center',
200
+ 'flex-end',
201
+ 'space-between',
202
+ 'space-around',
203
+ 'space-evenly',
204
+ ].includes(value),
205
+ },
206
+ /**
207
+ * @type {"flex-start" | "center" | "flex-end" }
208
+ * @default 'flex-start'
209
+ * @description 纵向对齐方式
210
+ */
211
+ align: {
212
+ type: [alignItemsEnum, String],
213
+ default: 'flex-start',
214
+ validator: (value: string) => ['flex-start', 'center', 'flex-end'].includes(value),
215
+ },
216
+ /**
217
+ * @type {"8px" | "16px" | "24px" }
218
+ * @description 间距
219
+ */
220
+ gap: {
221
+ type: [gapEnum, String],
222
+ },
223
+ /**
224
+ * @type {"nowrap" | "wrap" | "wrap-reverse" }
225
+ * @default 'nowrap'
226
+ * @description 是否换行
227
+ */
228
+ flexWrap: {
229
+ type: [flexWrapEnum, String],
230
+ default: 'nowrap',
231
+ validator: (value: string) => ['nowrap', 'wrap', 'wrap-reverse'].includes(value),
232
+ },
233
+ /**
234
+ * @type
235
+ * @default 0
236
+ * @description 尺寸
237
+ */
238
+ flexGrow: {
239
+ type: [Number, String],
240
+ default: 0,
241
+ },
242
+ /**
243
+ * @type
244
+ * @default '100%'
245
+ * @description 宽度
246
+ */
247
+ width: {
248
+ type: [String],
249
+ default: '100%',
250
+ },
251
+ /**
252
+ * @type
253
+ * @default '100%'
254
+ * @description 高度
255
+ */
256
+ height: {
257
+ type: [String],
258
+ default: '100%',
259
+ },
260
+ /**
261
+ * @type
262
+ * @default ''
263
+ * @description 最小宽度
264
+ */
265
+ minWidth: {
266
+ type: [String],
267
+ default: '',
268
+ },
269
+ /**
270
+ * @type
271
+ * @default ''
272
+ * @description 最小高度
273
+ */
274
+ minHeigth: {
275
+ type: [String],
276
+ default: '',
277
+ },
278
+ /**
279
+ * @type
280
+ * @default false
281
+ * @description 可拖拽
282
+ */
283
+ resizable: {
284
+ type: [Boolean, String],
285
+ default: false,
286
+ },
287
+ flexShrink: {
288
+ type: [String],
289
+ default: 'initial',
290
+ },
291
+ })
292
+ watch(props, (val) => {
293
+ divWidth.value = val.width + '' ? val.width + '' : '100%'
294
+ divHeight.value = val.height + '' ? val.height + '' : '100%'
295
+ })
296
+ </script>
297
+ <style scoped lang="scss"></style>