adtec-core-package 0.2.4 → 0.2.5

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 (156) hide show
  1. package/.editorconfig +6 -6
  2. package/.prettierrc.json +7 -7
  3. package/.vscode/extensions.json +8 -8
  4. package/README.md +39 -39
  5. package/env.d.ts +1 -1
  6. package/eslint.config.js +56 -56
  7. package/index.html +13 -13
  8. package/package.json +56 -56
  9. package/src/App.vue +9 -9
  10. package/src/api/BasicApi.ts +17 -0
  11. package/src/api/SysUserApi.ts +35 -0
  12. package/src/assets/base.css +86 -86
  13. package/src/assets/logo.svg +1 -1
  14. package/src/assets/main.css +35 -35
  15. package/src/assets/style/transition.scss +49 -49
  16. package/src/components/OperationAuth/operationAuth.vue +26 -26
  17. package/src/components/Search/ElIconSearch.vue +239 -239
  18. package/src/components/Search/ElSearch.vue +132 -132
  19. package/src/components/business/userSelect.vue +412 -0
  20. package/src/components/icon/ElIconBtn.vue +182 -182
  21. package/src/components/icon/ElIcons.vue +38 -38
  22. package/src/components/upload/ElUploads.vue +279 -279
  23. package/src/css/elementUI/affix.scss +7 -7
  24. package/src/css/elementUI/alert.scss +115 -115
  25. package/src/css/elementUI/anchor-link.scss +41 -41
  26. package/src/css/elementUI/anchor.scss +88 -88
  27. package/src/css/elementUI/aside.scss +8 -8
  28. package/src/css/elementUI/avatar.scss +55 -55
  29. package/src/css/elementUI/backtop.scss +29 -29
  30. package/src/css/elementUI/badge.scss +58 -58
  31. package/src/css/elementUI/base.scss +3 -3
  32. package/src/css/elementUI/breadcrumb.scss +62 -62
  33. package/src/css/elementUI/button-group.scss +80 -80
  34. package/src/css/elementUI/button.scss +304 -304
  35. package/src/css/elementUI/calendar.scss +80 -80
  36. package/src/css/elementUI/card.scss +45 -45
  37. package/src/css/elementUI/carousel-item.scss +58 -58
  38. package/src/css/elementUI/carousel.scss +188 -188
  39. package/src/css/elementUI/cascader-panel.scss +138 -138
  40. package/src/css/elementUI/cascader.scss +230 -230
  41. package/src/css/elementUI/check-tag.scss +60 -60
  42. package/src/css/elementUI/checkbox-button.scss +140 -140
  43. package/src/css/elementUI/checkbox-group.scss +7 -7
  44. package/src/css/elementUI/checkbox.scss +298 -298
  45. package/src/css/elementUI/col.scss +48 -48
  46. package/src/css/elementUI/collapse.scss +70 -70
  47. package/src/css/elementUI/color/index.scss +20 -20
  48. package/src/css/elementUI/color-picker.scss +392 -392
  49. package/src/css/elementUI/common/popup.scss +47 -47
  50. package/src/css/elementUI/common/transition.scss +122 -122
  51. package/src/css/elementUI/container.scss +14 -14
  52. package/src/css/elementUI/dark/css-vars.scss +39 -39
  53. package/src/css/elementUI/dark/var.scss +222 -222
  54. package/src/css/elementUI/date-picker/date-picker.scss +110 -110
  55. package/src/css/elementUI/date-picker/date-range-picker.scss +113 -113
  56. package/src/css/elementUI/date-picker/date-table.scss +158 -158
  57. package/src/css/elementUI/date-picker/month-table.scss +112 -112
  58. package/src/css/elementUI/date-picker/picker-panel.scss +131 -131
  59. package/src/css/elementUI/date-picker/time-picker.scss +90 -90
  60. package/src/css/elementUI/date-picker/time-range-picker.scss +33 -33
  61. package/src/css/elementUI/date-picker/time-spinner.scss +111 -111
  62. package/src/css/elementUI/date-picker/year-table.scss +108 -108
  63. package/src/css/elementUI/date-picker.scss +9 -9
  64. package/src/css/elementUI/descriptions-item.scss +73 -73
  65. package/src/css/elementUI/descriptions.scss +152 -152
  66. package/src/css/elementUI/dialog.scss +199 -199
  67. package/src/css/elementUI/display.scss +12 -12
  68. package/src/css/elementUI/divider.scss +48 -48
  69. package/src/css/elementUI/dropdown.scss +208 -208
  70. package/src/css/elementUI/empty.scss +49 -49
  71. package/src/css/elementUI/footer.scss +12 -12
  72. package/src/css/elementUI/form.scss +243 -243
  73. package/src/css/elementUI/header.scss +12 -12
  74. package/src/css/elementUI/icon.scss +45 -45
  75. package/src/css/elementUI/image-viewer.scss +139 -139
  76. package/src/css/elementUI/image.scss +49 -49
  77. package/src/css/elementUI/index.scss +110 -110
  78. package/src/css/elementUI/input-number.scss +178 -178
  79. package/src/css/elementUI/input.scss +478 -478
  80. package/src/css/elementUI/link.scss +90 -90
  81. package/src/css/elementUI/loading.scss +104 -104
  82. package/src/css/elementUI/main.scss +14 -14
  83. package/src/css/elementUI/mention.scss +88 -88
  84. package/src/css/elementUI/menu.scss +339 -339
  85. package/src/css/elementUI/message-box.scss +213 -213
  86. package/src/css/elementUI/message.scss +98 -98
  87. package/src/css/elementUI/mixins/_button.scss +165 -165
  88. package/src/css/elementUI/mixins/_col.scss +33 -33
  89. package/src/css/elementUI/mixins/_var.scss +67 -67
  90. package/src/css/elementUI/mixins/config.scss +5 -5
  91. package/src/css/elementUI/mixins/function.scss +88 -88
  92. package/src/css/elementUI/mixins/mixins.scss +237 -237
  93. package/src/css/elementUI/mixins/utils.scss +39 -39
  94. package/src/css/elementUI/notification.scss +104 -104
  95. package/src/css/elementUI/option-group.scss +33 -33
  96. package/src/css/elementUI/option.scss +71 -71
  97. package/src/css/elementUI/overlay.scss +17 -17
  98. package/src/css/elementUI/page-header.scss +60 -60
  99. package/src/css/elementUI/pagination.scss +238 -238
  100. package/src/css/elementUI/popconfirm.scss +16 -16
  101. package/src/css/elementUI/popover.scss +61 -61
  102. package/src/css/elementUI/popper.scss +106 -106
  103. package/src/css/elementUI/progress.scss +179 -179
  104. package/src/css/elementUI/radio-button.scss +169 -169
  105. package/src/css/elementUI/radio-group.scss +9 -9
  106. package/src/css/elementUI/radio.scss +215 -215
  107. package/src/css/elementUI/rate.scss +108 -108
  108. package/src/css/elementUI/reset.scss +98 -98
  109. package/src/css/elementUI/result.scss +57 -57
  110. package/src/css/elementUI/row.scss +35 -35
  111. package/src/css/elementUI/scrollbar.scss +97 -97
  112. package/src/css/elementUI/segmented.scss +183 -183
  113. package/src/css/elementUI/select-dropdown-v2.scss +1 -1
  114. package/src/css/elementUI/select-dropdown.scss +57 -57
  115. package/src/css/elementUI/select-v2.scss +4 -4
  116. package/src/css/elementUI/select.scss +253 -253
  117. package/src/css/elementUI/skeleton-item.scss +83 -83
  118. package/src/css/elementUI/skeleton.scss +44 -44
  119. package/src/css/elementUI/slider.scss +212 -212
  120. package/src/css/elementUI/space.scss +20 -20
  121. package/src/css/elementUI/spinner.scss +43 -43
  122. package/src/css/elementUI/statistic.scss +35 -35
  123. package/src/css/elementUI/step.scss +316 -316
  124. package/src/css/elementUI/steps.scss +21 -21
  125. package/src/css/elementUI/switch.scss +300 -300
  126. package/src/css/elementUI/table-column.scss +98 -98
  127. package/src/css/elementUI/table-v2.scss +236 -236
  128. package/src/css/elementUI/tag.scss +181 -181
  129. package/src/css/elementUI/text.scss +51 -51
  130. package/src/css/elementUI/time-picker.scss +5 -5
  131. package/src/css/elementUI/time-select.scss +37 -37
  132. package/src/css/elementUI/timeline-item.scss +84 -84
  133. package/src/css/elementUI/timeline.scss +46 -46
  134. package/src/css/elementUI/tooltip-v2.scss +95 -95
  135. package/src/css/elementUI/tour.scss +187 -187
  136. package/src/css/elementUI/transfer.scss +203 -203
  137. package/src/css/elementUI/tree-select.scss +41 -41
  138. package/src/css/elementUI/tree.scss +134 -134
  139. package/src/css/elementUI/upload.scss +654 -654
  140. package/src/css/elementUI/var.scss +87 -87
  141. package/src/css/elementUI/virtual-list.scss +40 -40
  142. package/src/hooks/useDictHooks.ts +81 -0
  143. package/src/interface/IMdmDept.ts +82 -0
  144. package/src/interface/IOrgDeptInfo.ts +12 -0
  145. package/src/interface/ISysUserInfo.ts +70 -0
  146. package/src/interface/enum/FlexEnum.ts +85 -85
  147. package/src/main.ts +14 -14
  148. package/src/mixin/globalMixin.ts +34 -31
  149. package/src/router/index.ts +23 -23
  150. package/src/utils/encrypt.ts +10 -10
  151. package/src/utils/request.ts +55 -55
  152. package/tsconfig.app.json +12 -12
  153. package/tsconfig.json +11 -11
  154. package/tsconfig.node.json +18 -18
  155. package/vite.config.ts +38 -38
  156. /package/src/components/autoToolTip/{index.vue → ElAutoToolTip.vue} +0 -0
@@ -1,239 +1,239 @@
1
- <!--创建人 丁盼-->
2
- <!--说明: ELIconSearch-->
3
- <!--创建时间: 2024/11/25 上午10:17-->
4
- <!--修改时间: 2024/11/25 上午10:17-->
5
- <template>
6
- <el-popover
7
- :popper-options="{
8
- modifiers: [
9
- {
10
- name: 'offset',
11
- options: {
12
- offset: elementType === 'button' ? [0 - 15, 20] : [0 - 15, 12],
13
- },
14
- },
15
- ],
16
- }"
17
- @hide="visible = false"
18
- :popper-style="{ paddingTop: 0 }"
19
- ref="popoverRef"
20
- :virtual-ref="buttonRef"
21
- placement="right-end"
22
- :width="width"
23
- trigger="click"
24
- :teleported="false"
25
- :visible="visible"
26
- >
27
- <template #reference>
28
- <el-tooltip :content="tip" placement="top" style="cursor: pointer">
29
- <el-button v-if="elementType === 'button'" style="padding: 8px 10px; margin-left: 4px">
30
- <el-icon
31
- ref="buttonRef"
32
- :model-value="iconName"
33
- :style="style"
34
- :tip="tip"
35
- @click="iconClick"
36
- :class="getClass"
37
- >
38
- <svg v-if="selcomp" aria-hidden="true">
39
- <use :href="'#' + iconName"></use>
40
- </svg>
41
- <component v-else :is="iconName"></component>
42
- </el-icon>
43
- </el-button>
44
- <el-icon
45
- ref="buttonRef"
46
- v-else
47
- :model-value="iconName"
48
- :style="style"
49
- :tip="tip"
50
- @click="iconClick"
51
- class="icon-btn"
52
- :class="getClass"
53
- >
54
- <svg v-if="selcomp" class="icon" aria-hidden="true">
55
- <use :href="'#' + iconName"></use>
56
- </svg>
57
- <component v-else :is="iconName"></component>
58
- </el-icon>
59
- </el-tooltip>
60
- </template>
61
- <el-flex :vertical="true" @keypress="keypress">
62
- <el-flex
63
- height="45px"
64
- style="border-bottom: var(--border); margin-bottom: 10px"
65
- align="center"
66
- >
67
- <el-flex>
68
- <el-text style="font-size: 16px">{{ title }}</el-text>
69
- </el-flex>
70
- <el-flex align="center" justify="flex-end">
71
- <el-icons
72
- model-value="Close"
73
- style="font-size: 16px; cursor: pointer"
74
- @click="visible = false"
75
- ></el-icons>
76
- </el-flex>
77
- </el-flex>
78
- <slot></slot>
79
- <el-flex
80
- align="flex-end"
81
- justify="flex-end"
82
- height="40px"
83
- style="border-top: var(--border)"
84
- >
85
- <el-button @click="reset">重置</el-button>
86
- <el-button type="primary" @click="search">查询</el-button>
87
- </el-flex>
88
- </el-flex>
89
- </el-popover>
90
- </template>
91
- <script setup lang="ts">
92
- // 定义Props类型
93
- import { useVModel } from '@vueuse/core'
94
- import { computed, ref, unref } from 'vue'
95
- import ElFlex from '../ElFlex/ElFlex.vue'
96
- import ElIcons from '../icon/ElIcons.vue'
97
-
98
- const iconClick = () => {
99
- unref(popoverRef).popperRef?.delayHide?.()
100
- visible.value = !visible.value
101
- }
102
- const keypress = (e: KeyboardEvent) => {
103
- if (e.key === 'Enter') {
104
- visible.value = false
105
- emit('search')
106
- }
107
- }
108
- const search = () => {
109
- visible.value = false
110
- emit('search')
111
- }
112
- const reset = () => {
113
- emit('reset')
114
- }
115
- const visible = ref(false)
116
- const buttonRef = ref()
117
- const popoverRef = ref()
118
- const props = defineProps({
119
- /**
120
- * @type Object
121
- * @default {}
122
- * @description 样式对象
123
- */
124
- style: {
125
- type: Object,
126
- default: () => ({}),
127
- },
128
- /**
129
- * @type string
130
- * @default ''
131
- * @description 提示文字
132
- */
133
- tip: {
134
- type: String,
135
- default: '高级筛选',
136
- },
137
- /**
138
- * @type number
139
- * @default 400
140
- * @description 宽度
141
- */
142
- width: {
143
- type: Number,
144
- default: 350,
145
- },
146
- title: {
147
- type: String,
148
- default: '高级筛选',
149
- },
150
- modelValue: {
151
- type: String,
152
- default: 'adtec-filter',
153
- },
154
- /**
155
- * @type {'small'|'default'|'large'}
156
- * @default 'default'
157
- * @description 图标大小
158
- */
159
- size: {
160
- type: String,
161
- default: 'default',
162
- // 注意:在`<script setup>`中,直接使用函数进行验证,JSDoc辅助IDE提示
163
- validator: (value: string) => ['large', 'default', 'small'].includes(value),
164
- },
165
- /**
166
- * @type {"default" | "success" | "warning" | "info" | "primary" | "danger"}
167
- * @default 'default'
168
- * @description 图标类型
169
- */
170
- type: {
171
- type: String,
172
- default: 'default',
173
- validator: (value: string) =>
174
- ['default', 'success', 'warning', 'info', 'primary', 'danger'].includes(value),
175
- },
176
- /**
177
- * @type {"icon" | "button"}
178
- * @default 'icon'
179
- * @description 元素类型
180
- */
181
- elementType: {
182
- type: String,
183
- default: 'icon',
184
- },
185
- disabled: {
186
- type: Boolean,
187
- default: false,
188
- },
189
- })
190
-
191
- const getClass = computed(() => {
192
- let className = 'icon-btn--' + props.type
193
- if (props.disabled) {
194
- className += ' icon-btn--disabled'
195
- }
196
- className += ' icon-btn--size-' + props.size
197
- return className
198
- })
199
- const emit = defineEmits(['update:modelValue', 'click', 'search', 'reset'])
200
- const iconName = useVModel(props, 'modelValue', emit)
201
-
202
- const selcomp = computed(() => {
203
- if (iconName.value?.includes('adtec')) {
204
- return true
205
- } else {
206
- return false
207
- }
208
- })
209
- </script>
210
- <style scoped lang="scss">
211
- .icon-btn {
212
- margin-right: 5px;
213
- cursor: pointer;
214
- --el-button-hover-bg-color: var(--el-color-primary-light-3);
215
- &:hover {
216
- color: var(--el-button-hover-bg-color);
217
- }
218
- &--disabled {
219
- color: var(--el-color-disabled-text-color);
220
- cursor: not-allowed !important;
221
- }
222
- &--size-large {
223
- font-size: var(--el-font-size-large);
224
- }
225
- &--size-default {
226
- font-size: var(--el-font-size-base);
227
- }
228
- &--size-small {
229
- font-size: var(--el-font-size-small);
230
- }
231
- @each $type in (primary, success, warning, danger, info) {
232
- &--#{$type} {
233
- --el-button-hover-bg-color: var(--el-color-#{$type}-light-3);
234
- --el-button-disabled-bg-color: var(--el-color-#{$type}-light-5);
235
- color: var(--el-color-#{$type});
236
- }
237
- }
238
- }
239
- </style>
1
+ <!--创建人 丁盼-->
2
+ <!--说明: ELIconSearch-->
3
+ <!--创建时间: 2024/11/25 上午10:17-->
4
+ <!--修改时间: 2024/11/25 上午10:17-->
5
+ <template>
6
+ <el-popover
7
+ :popper-options="{
8
+ modifiers: [
9
+ {
10
+ name: 'offset',
11
+ options: {
12
+ offset: elementType === 'button' ? [0 - 15, 20] : [0 - 15, 12],
13
+ },
14
+ },
15
+ ],
16
+ }"
17
+ @hide="visible = false"
18
+ :popper-style="{ paddingTop: 0 }"
19
+ ref="popoverRef"
20
+ :virtual-ref="buttonRef"
21
+ placement="right-end"
22
+ :width="width"
23
+ trigger="click"
24
+ :teleported="false"
25
+ :visible="visible"
26
+ >
27
+ <template #reference>
28
+ <el-tooltip :content="tip" placement="top" style="cursor: pointer">
29
+ <el-button v-if="elementType === 'button'" style="padding: 8px 10px; margin-left: 4px">
30
+ <el-icon
31
+ ref="buttonRef"
32
+ :model-value="iconName"
33
+ :style="style"
34
+ :tip="tip"
35
+ @click="iconClick"
36
+ :class="getClass"
37
+ >
38
+ <svg v-if="selcomp" aria-hidden="true">
39
+ <use :href="'#' + iconName"></use>
40
+ </svg>
41
+ <component v-else :is="iconName"></component>
42
+ </el-icon>
43
+ </el-button>
44
+ <el-icon
45
+ ref="buttonRef"
46
+ v-else
47
+ :model-value="iconName"
48
+ :style="style"
49
+ :tip="tip"
50
+ @click="iconClick"
51
+ class="icon-btn"
52
+ :class="getClass"
53
+ >
54
+ <svg v-if="selcomp" class="icon" aria-hidden="true">
55
+ <use :href="'#' + iconName"></use>
56
+ </svg>
57
+ <component v-else :is="iconName"></component>
58
+ </el-icon>
59
+ </el-tooltip>
60
+ </template>
61
+ <el-flex :vertical="true" @keypress="keypress">
62
+ <el-flex
63
+ height="45px"
64
+ style="border-bottom: var(--border); margin-bottom: 10px"
65
+ align="center"
66
+ >
67
+ <el-flex>
68
+ <el-text style="font-size: 16px">{{ title }}</el-text>
69
+ </el-flex>
70
+ <el-flex align="center" justify="flex-end">
71
+ <el-icons
72
+ model-value="Close"
73
+ style="font-size: 16px; cursor: pointer"
74
+ @click="visible = false"
75
+ ></el-icons>
76
+ </el-flex>
77
+ </el-flex>
78
+ <slot></slot>
79
+ <el-flex
80
+ align="flex-end"
81
+ justify="flex-end"
82
+ height="40px"
83
+ style="border-top: var(--border)"
84
+ >
85
+ <el-button @click="reset">重置</el-button>
86
+ <el-button type="primary" @click="search">查询</el-button>
87
+ </el-flex>
88
+ </el-flex>
89
+ </el-popover>
90
+ </template>
91
+ <script setup lang="ts">
92
+ // 定义Props类型
93
+ import { useVModel } from '@vueuse/core'
94
+ import { computed, ref, unref } from 'vue'
95
+ import ElFlex from '../ElFlex/ElFlex.vue'
96
+ import ElIcons from '../icon/ElIcons.vue'
97
+
98
+ const iconClick = () => {
99
+ unref(popoverRef).popperRef?.delayHide?.()
100
+ visible.value = !visible.value
101
+ }
102
+ const keypress = (e: KeyboardEvent) => {
103
+ if (e.key === 'Enter') {
104
+ visible.value = false
105
+ emit('search')
106
+ }
107
+ }
108
+ const search = () => {
109
+ visible.value = false
110
+ emit('search')
111
+ }
112
+ const reset = () => {
113
+ emit('reset')
114
+ }
115
+ const visible = ref(false)
116
+ const buttonRef = ref()
117
+ const popoverRef = ref()
118
+ const props = defineProps({
119
+ /**
120
+ * @type Object
121
+ * @default {}
122
+ * @description 样式对象
123
+ */
124
+ style: {
125
+ type: Object,
126
+ default: () => ({}),
127
+ },
128
+ /**
129
+ * @type string
130
+ * @default ''
131
+ * @description 提示文字
132
+ */
133
+ tip: {
134
+ type: String,
135
+ default: '高级筛选',
136
+ },
137
+ /**
138
+ * @type number
139
+ * @default 400
140
+ * @description 宽度
141
+ */
142
+ width: {
143
+ type: Number,
144
+ default: 350,
145
+ },
146
+ title: {
147
+ type: String,
148
+ default: '高级筛选',
149
+ },
150
+ modelValue: {
151
+ type: String,
152
+ default: 'adtec-filter',
153
+ },
154
+ /**
155
+ * @type {'small'|'default'|'large'}
156
+ * @default 'default'
157
+ * @description 图标大小
158
+ */
159
+ size: {
160
+ type: String,
161
+ default: 'default',
162
+ // 注意:在`<script setup>`中,直接使用函数进行验证,JSDoc辅助IDE提示
163
+ validator: (value: string) => ['large', 'default', 'small'].includes(value),
164
+ },
165
+ /**
166
+ * @type {"default" | "success" | "warning" | "info" | "primary" | "danger"}
167
+ * @default 'default'
168
+ * @description 图标类型
169
+ */
170
+ type: {
171
+ type: String,
172
+ default: 'default',
173
+ validator: (value: string) =>
174
+ ['default', 'success', 'warning', 'info', 'primary', 'danger'].includes(value),
175
+ },
176
+ /**
177
+ * @type {"icon" | "button"}
178
+ * @default 'icon'
179
+ * @description 元素类型
180
+ */
181
+ elementType: {
182
+ type: String,
183
+ default: 'icon',
184
+ },
185
+ disabled: {
186
+ type: Boolean,
187
+ default: false,
188
+ },
189
+ })
190
+
191
+ const getClass = computed(() => {
192
+ let className = 'icon-btn--' + props.type
193
+ if (props.disabled) {
194
+ className += ' icon-btn--disabled'
195
+ }
196
+ className += ' icon-btn--size-' + props.size
197
+ return className
198
+ })
199
+ const emit = defineEmits(['update:modelValue', 'click', 'search', 'reset'])
200
+ const iconName = useVModel(props, 'modelValue', emit)
201
+
202
+ const selcomp = computed(() => {
203
+ if (iconName.value?.includes('adtec')) {
204
+ return true
205
+ } else {
206
+ return false
207
+ }
208
+ })
209
+ </script>
210
+ <style scoped lang="scss">
211
+ .icon-btn {
212
+ margin-right: 5px;
213
+ cursor: pointer;
214
+ --el-button-hover-bg-color: var(--el-color-primary-light-3);
215
+ &:hover {
216
+ color: var(--el-button-hover-bg-color);
217
+ }
218
+ &--disabled {
219
+ color: var(--el-color-disabled-text-color);
220
+ cursor: not-allowed !important;
221
+ }
222
+ &--size-large {
223
+ font-size: var(--el-font-size-large);
224
+ }
225
+ &--size-default {
226
+ font-size: var(--el-font-size-base);
227
+ }
228
+ &--size-small {
229
+ font-size: var(--el-font-size-small);
230
+ }
231
+ @each $type in (primary, success, warning, danger, info) {
232
+ &--#{$type} {
233
+ --el-button-hover-bg-color: var(--el-color-#{$type}-light-3);
234
+ --el-button-disabled-bg-color: var(--el-color-#{$type}-light-5);
235
+ color: var(--el-color-#{$type});
236
+ }
237
+ }
238
+ }
239
+ </style>