adtec-core-package 0.4.0 → 0.4.2

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 (207) hide show
  1. package/.editorconfig +6 -6
  2. package/.prettierrc.json +7 -7
  3. package/.vscode/extensions.json +8 -8
  4. package/README.en.md +36 -36
  5. package/README.md +39 -39
  6. package/env.d.ts +1 -1
  7. package/eslint.config.js +56 -56
  8. package/index.html +13 -13
  9. package/package.json +59 -59
  10. package/src/App.vue +9 -9
  11. package/src/api/BasicApi.ts +17 -17
  12. package/src/api/DocumentApi.ts +27 -27
  13. package/src/api/SysDictCacheApi.ts +26 -26
  14. package/src/api/SysUserApi.ts +35 -35
  15. package/src/api/framework.ts +12 -12
  16. package/src/assets/base.css +86 -86
  17. package/src/assets/logo.svg +1 -1
  18. package/src/assets/main.css +35 -35
  19. package/src/assets/style/ant.scss +19 -19
  20. package/src/assets/style/index.less +180 -180
  21. package/src/assets/style/transition.scss +49 -49
  22. package/src/components/ElFlex/ElFlex.vue +297 -297
  23. package/src/components/OperationAuth/operationAuth.vue +26 -26
  24. package/src/components/Search/ElIconSearch.vue +260 -239
  25. package/src/components/Search/ElSearch.vue +154 -154
  26. package/src/components/Table/ElTableColumnEdit.vue +218 -218
  27. package/src/components/Title/ElTitle.vue +49 -49
  28. package/src/components/autoToolTip/ElAutoToolTip.vue +61 -61
  29. package/src/components/baseEcharts/index.vue +48 -48
  30. package/src/components/business/userSelect.vue +412 -412
  31. package/src/components/icon/ElIconBtn.vue +182 -182
  32. package/src/components/icon/ElIcons.vue +38 -38
  33. package/src/components/upload/ElUploads.vue +286 -279
  34. package/src/components/upload/FileView.vue +158 -158
  35. package/src/components/upload/FileViewComponents.vue +57 -57
  36. package/src/config/ElementPlusConfig.ts +95 -95
  37. package/src/css/elementUI/affix.scss +7 -7
  38. package/src/css/elementUI/alert.scss +115 -115
  39. package/src/css/elementUI/anchor-link.scss +41 -41
  40. package/src/css/elementUI/anchor.scss +88 -88
  41. package/src/css/elementUI/aside.scss +8 -8
  42. package/src/css/elementUI/autocomplete.scss +89 -89
  43. package/src/css/elementUI/avatar.scss +55 -55
  44. package/src/css/elementUI/backtop.scss +29 -29
  45. package/src/css/elementUI/badge.scss +58 -58
  46. package/src/css/elementUI/base.scss +3 -3
  47. package/src/css/elementUI/breadcrumb.scss +62 -62
  48. package/src/css/elementUI/button-group.scss +80 -80
  49. package/src/css/elementUI/button.scss +304 -304
  50. package/src/css/elementUI/calendar.scss +80 -80
  51. package/src/css/elementUI/card.scss +45 -45
  52. package/src/css/elementUI/carousel-item.scss +58 -58
  53. package/src/css/elementUI/carousel.scss +188 -188
  54. package/src/css/elementUI/cascader-panel.scss +138 -138
  55. package/src/css/elementUI/cascader.scss +230 -230
  56. package/src/css/elementUI/check-tag.scss +60 -60
  57. package/src/css/elementUI/checkbox-button.scss +140 -140
  58. package/src/css/elementUI/checkbox-group.scss +7 -7
  59. package/src/css/elementUI/checkbox.scss +298 -298
  60. package/src/css/elementUI/col.scss +48 -48
  61. package/src/css/elementUI/collapse.scss +70 -70
  62. package/src/css/elementUI/color/index.scss +20 -20
  63. package/src/css/elementUI/color-picker.scss +392 -392
  64. package/src/css/elementUI/common/popup.scss +47 -47
  65. package/src/css/elementUI/common/transition.scss +122 -122
  66. package/src/css/elementUI/common/var.scss +1549 -1549
  67. package/src/css/elementUI/container.scss +14 -14
  68. package/src/css/elementUI/dark/css-vars.scss +39 -39
  69. package/src/css/elementUI/dark/var.scss +222 -222
  70. package/src/css/elementUI/date-picker/date-picker.scss +110 -110
  71. package/src/css/elementUI/date-picker/date-range-picker.scss +113 -113
  72. package/src/css/elementUI/date-picker/date-table.scss +158 -158
  73. package/src/css/elementUI/date-picker/month-table.scss +112 -112
  74. package/src/css/elementUI/date-picker/picker-panel.scss +131 -131
  75. package/src/css/elementUI/date-picker/picker.scss +219 -219
  76. package/src/css/elementUI/date-picker/time-picker.scss +90 -90
  77. package/src/css/elementUI/date-picker/time-range-picker.scss +33 -33
  78. package/src/css/elementUI/date-picker/time-spinner.scss +111 -111
  79. package/src/css/elementUI/date-picker/year-table.scss +108 -108
  80. package/src/css/elementUI/date-picker.scss +9 -9
  81. package/src/css/elementUI/descriptions-item.scss +73 -73
  82. package/src/css/elementUI/descriptions.scss +152 -152
  83. package/src/css/elementUI/dialog.scss +199 -199
  84. package/src/css/elementUI/display.scss +12 -12
  85. package/src/css/elementUI/divider.scss +48 -48
  86. package/src/css/elementUI/drawer.scss +164 -164
  87. package/src/css/elementUI/dropdown.scss +208 -208
  88. package/src/css/elementUI/empty.scss +49 -49
  89. package/src/css/elementUI/footer.scss +12 -12
  90. package/src/css/elementUI/form.scss +243 -243
  91. package/src/css/elementUI/header.scss +12 -12
  92. package/src/css/elementUI/icon.scss +45 -45
  93. package/src/css/elementUI/image-viewer.scss +139 -139
  94. package/src/css/elementUI/image.scss +49 -49
  95. package/src/css/elementUI/index.scss +110 -110
  96. package/src/css/elementUI/input-number.scss +178 -178
  97. package/src/css/elementUI/input.scss +478 -478
  98. package/src/css/elementUI/link.scss +90 -90
  99. package/src/css/elementUI/loading.scss +104 -104
  100. package/src/css/elementUI/main.scss +14 -14
  101. package/src/css/elementUI/mention.scss +88 -88
  102. package/src/css/elementUI/menu.scss +339 -339
  103. package/src/css/elementUI/message-box.scss +213 -213
  104. package/src/css/elementUI/message.scss +98 -98
  105. package/src/css/elementUI/mixins/_button.scss +165 -165
  106. package/src/css/elementUI/mixins/_col.scss +33 -33
  107. package/src/css/elementUI/mixins/_var.scss +67 -67
  108. package/src/css/elementUI/mixins/config.scss +5 -5
  109. package/src/css/elementUI/mixins/function.scss +88 -88
  110. package/src/css/elementUI/mixins/mixins.scss +237 -237
  111. package/src/css/elementUI/mixins/utils.scss +39 -39
  112. package/src/css/elementUI/notification.scss +104 -104
  113. package/src/css/elementUI/option-group.scss +33 -33
  114. package/src/css/elementUI/option.scss +71 -71
  115. package/src/css/elementUI/overlay.scss +17 -17
  116. package/src/css/elementUI/page-header.scss +60 -60
  117. package/src/css/elementUI/pagination.scss +238 -238
  118. package/src/css/elementUI/popconfirm.scss +16 -16
  119. package/src/css/elementUI/popover.scss +61 -61
  120. package/src/css/elementUI/popper.scss +106 -106
  121. package/src/css/elementUI/progress.scss +179 -179
  122. package/src/css/elementUI/radio-button.scss +169 -169
  123. package/src/css/elementUI/radio-group.scss +9 -9
  124. package/src/css/elementUI/radio.scss +215 -215
  125. package/src/css/elementUI/rate.scss +108 -108
  126. package/src/css/elementUI/reset.scss +98 -98
  127. package/src/css/elementUI/result.scss +57 -57
  128. package/src/css/elementUI/row.scss +35 -35
  129. package/src/css/elementUI/scrollbar.scss +97 -97
  130. package/src/css/elementUI/segmented.scss +183 -183
  131. package/src/css/elementUI/select-dropdown-v2.scss +1 -1
  132. package/src/css/elementUI/select-dropdown.scss +57 -57
  133. package/src/css/elementUI/select-v2.scss +4 -4
  134. package/src/css/elementUI/select.scss +253 -253
  135. package/src/css/elementUI/skeleton-item.scss +83 -83
  136. package/src/css/elementUI/skeleton.scss +44 -44
  137. package/src/css/elementUI/slider.scss +212 -212
  138. package/src/css/elementUI/space.scss +20 -20
  139. package/src/css/elementUI/spinner.scss +43 -43
  140. package/src/css/elementUI/statistic.scss +35 -35
  141. package/src/css/elementUI/step.scss +316 -316
  142. package/src/css/elementUI/steps.scss +21 -21
  143. package/src/css/elementUI/switch.scss +300 -300
  144. package/src/css/elementUI/table-column.scss +98 -98
  145. package/src/css/elementUI/table-v2.scss +236 -236
  146. package/src/css/elementUI/table.scss +694 -694
  147. package/src/css/elementUI/tabs.scss +659 -659
  148. package/src/css/elementUI/tag.scss +181 -181
  149. package/src/css/elementUI/text.scss +51 -51
  150. package/src/css/elementUI/time-picker.scss +5 -5
  151. package/src/css/elementUI/time-select.scss +37 -37
  152. package/src/css/elementUI/timeline-item.scss +84 -84
  153. package/src/css/elementUI/timeline.scss +46 -46
  154. package/src/css/elementUI/tooltip-v2.scss +95 -95
  155. package/src/css/elementUI/tour.scss +187 -187
  156. package/src/css/elementUI/transfer.scss +203 -203
  157. package/src/css/elementUI/tree-select.scss +41 -41
  158. package/src/css/elementUI/tree.scss +134 -134
  159. package/src/css/elementUI/upload.scss +654 -654
  160. package/src/css/elementUI/var.scss +87 -87
  161. package/src/css/elementUI/virtual-list.scss +40 -40
  162. package/src/directives/vKeydown.ts +93 -93
  163. package/src/hooks/useDictHooks.ts +79 -76
  164. package/src/hooks/useEcharts.ts +58 -58
  165. package/src/hooks/useFileView.ts +34 -34
  166. package/src/hooks/useMessageHooks.ts +132 -132
  167. package/src/hooks/useResetRefHooks.ts +18 -18
  168. package/src/interface/BaseEntity.ts +28 -28
  169. package/src/interface/IMdmDept.ts +82 -82
  170. package/src/interface/IOrgDeptInfo.ts +12 -12
  171. package/src/interface/ISysDictDataCacheVo.ts +46 -46
  172. package/src/interface/ISysDictType.ts +37 -37
  173. package/src/interface/ISysMenuDataVo.ts +22 -22
  174. package/src/interface/ISysMenuInfoVo.ts +83 -83
  175. package/src/interface/ISysMenuOperationVo.ts +21 -21
  176. package/src/interface/ISysUploadFiles.ts +16 -16
  177. package/src/interface/ISysUserInfo.ts +70 -70
  178. package/src/interface/IUserPermissionVo.ts +34 -34
  179. package/src/interface/Message.ts +69 -69
  180. package/src/interface/PageData.ts +17 -17
  181. package/src/interface/ResponseData.ts +16 -16
  182. package/src/interface/dictMapType.ts +11 -11
  183. package/src/interface/enum/FlexEnum.ts +85 -85
  184. package/src/interface/enum/MessageEnum.ts +41 -41
  185. package/src/main.ts +14 -14
  186. package/src/mixin/globalMixin.ts +37 -37
  187. package/src/packages/index.ts +18 -18
  188. package/src/packages/text.vue +13 -13
  189. package/src/plugins/echartsConfig.ts +73 -73
  190. package/src/plugins/plugins.ts +12 -12
  191. package/src/router/index.ts +23 -23
  192. package/src/stores/dictStore.ts +27 -20
  193. package/src/stores/messageStore.ts +49 -49
  194. package/src/stores/permissionStore.ts +108 -108
  195. package/src/stores/storeConfig.ts +23 -23
  196. package/src/stores/userInfoStore.ts +31 -31
  197. package/src/utils/AxiosConfig.ts +216 -216
  198. package/src/utils/encrypt.ts +10 -10
  199. package/src/utils/request.ts +55 -55
  200. package/tsconfig.app.json +12 -12
  201. package/tsconfig.json +11 -11
  202. package/tsconfig.node.json +18 -18
  203. package/vite.config.ts +38 -38
  204. package/adtec-core-package/adtec-core-package.css +0 -1
  205. package/adtec-core-package/adtec-core-package.js +0 -41364
  206. package/adtec-core-package/adtec-core-package.umd.cjs +0 -79
  207. 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>
@@ -1,26 +1,26 @@
1
- <!--创建人:丁盼-->
2
- <!--说明: 操作权限控制组件-->
3
- <!--创建时间: 2024/8/29 下午2:31-->
4
- <!--修改时间: 2024/8/29 下午2:31-->
5
- <template>
6
- <slot v-if="IsOperationAuth()"></slot>
7
- </template>
8
- <script setup lang="ts">
9
- import { useRoute } from 'vue-router'
10
- import type { ISysMenuInfoVo } from '../../interface/ISysMenuInfoVo.ts'
11
- const route = useRoute()
12
-
13
- const IsOperationAuth = () => {
14
- const data: ISysMenuInfoVo = route.meta.sysMenuData as ISysMenuInfoVo
15
- const o = data.operation?.find((c) => c.code === props.operCode)
16
- if (o) {
17
- return true
18
- } else {
19
- return false
20
- }
21
- }
22
- const props = defineProps<{
23
- operCode: string
24
- }>()
25
- </script>
26
- <style scoped lang="scss"></style>
1
+ <!--创建人:丁盼-->
2
+ <!--说明: 操作权限控制组件-->
3
+ <!--创建时间: 2024/8/29 下午2:31-->
4
+ <!--修改时间: 2024/8/29 下午2:31-->
5
+ <template>
6
+ <slot v-if="IsOperationAuth()"></slot>
7
+ </template>
8
+ <script setup lang="ts">
9
+ import { useRoute } from 'vue-router'
10
+ import type { ISysMenuInfoVo } from '../../interface/ISysMenuInfoVo.ts'
11
+ const route = useRoute()
12
+
13
+ const IsOperationAuth = () => {
14
+ const data: ISysMenuInfoVo = route.meta.sysMenuData as ISysMenuInfoVo
15
+ const o = data.operation?.find((c) => c.code === props.operCode)
16
+ if (o) {
17
+ return true
18
+ } else {
19
+ return false
20
+ }
21
+ }
22
+ const props = defineProps<{
23
+ operCode: string
24
+ }>()
25
+ </script>
26
+ <style scoped lang="scss"></style>