@dt-frames/ui 1.0.13 → 1.0.15

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 (208) hide show
  1. package/es/components/curd/src/components/dialog.d.ts +20 -20
  2. package/es/components/curd/src/components/props.d.ts +2 -1
  3. package/es/components/curd/src/hooks/useCurd.d.ts +1 -0
  4. package/es/components/curd/src/types/curd.type.d.ts +2 -2
  5. package/es/components/forms/src/components/formButton.d.ts +1 -2
  6. package/es/components/forms/src/components/formIcon.d.ts +15 -15
  7. package/es/components/forms/src/hooks/useFormActions.d.ts +2 -2
  8. package/es/components/forms/src/index.d.ts +2 -2
  9. package/es/components/forms/src/types/form.type.d.ts +3 -17
  10. package/es/components/index.d.ts +1 -1
  11. package/es/components/modal/src/components/modal.d.ts +2 -2
  12. package/es/components/modal/src/components/modalFooter.d.ts +1 -1
  13. package/es/components/modal/src/index.d.ts +15 -15
  14. package/es/components/modal/src/props.d.ts +1 -1
  15. package/es/components/source/src/hooks/useFetch.d.ts +1 -1
  16. package/es/components/table/src/index.d.ts +3 -3
  17. package/es/components/table/src/props.d.ts +1 -2
  18. package/es/components/tree/src/props.d.ts +8 -1
  19. package/es/components/upload/src/upload.d.ts +3 -3
  20. package/es/index.js +43 -19
  21. package/es/style/components/icons/index.less +1 -1
  22. package/package.json +1 -10
  23. package/vite.config.js +10 -0
  24. package/src/assets/data/icons/actions.ts +0 -427
  25. package/src/assets/data/icons/code.ts +0 -10
  26. package/src/assets/data/icons/commuticate.ts +0 -190
  27. package/src/assets/data/icons/currency.ts +0 -46
  28. package/src/assets/data/icons/devices.ts +0 -128
  29. package/src/assets/data/icons/edit.ts +0 -165
  30. package/src/assets/data/icons/file.ts +0 -104
  31. package/src/assets/data/icons/math.ts +0 -53
  32. package/src/assets/data/icons/message.ts +0 -75
  33. package/src/assets/data/icons/navigate.ts +0 -181
  34. package/src/assets/data/icons/other.ts +0 -333
  35. package/src/assets/data/icons.ts +0 -58
  36. package/src/assets/imgs/header/avatar.png +0 -0
  37. package/src/assets/imgs/logo/logo.png +0 -0
  38. package/src/assets/locales/en_US.json +0 -3
  39. package/src/assets/locales/zh_CN.json +0 -3
  40. package/src/assets/style/index.less +0 -10
  41. package/src/assets/style/reset.less +0 -17
  42. package/src/components/container/index.less +0 -85
  43. package/src/components/container/index.ts +0 -8
  44. package/src/components/container/src/bar.ts +0 -107
  45. package/src/components/container/src/lazy-container.vue +0 -9
  46. package/src/components/container/src/scroll-bar.vue +0 -117
  47. package/src/components/container/src/scroll-container.vue +0 -61
  48. package/src/components/curd/index.ts +0 -5
  49. package/src/components/curd/src/components/dialog.vue +0 -73
  50. package/src/components/curd/src/components/props.ts +0 -32
  51. package/src/components/curd/src/hooks/useCurd.tsx +0 -87
  52. package/src/components/curd/src/types/curd.type.ts +0 -32
  53. package/src/components/excel/index.ts +0 -6
  54. package/src/components/excel/src/export2Excel.ts +0 -44
  55. package/src/components/forms/index.less +0 -107
  56. package/src/components/forms/index.ts +0 -11
  57. package/src/components/forms/src/componentMap.ts +0 -46
  58. package/src/components/forms/src/components/formButton.vue +0 -150
  59. package/src/components/forms/src/components/formIcon.vue +0 -51
  60. package/src/components/forms/src/components/formInputUseDialog.vue +0 -43
  61. package/src/components/forms/src/components/formItem.vue +0 -420
  62. package/src/components/forms/src/components/radioButton.vue +0 -58
  63. package/src/components/forms/src/const/form.const.ts +0 -7
  64. package/src/components/forms/src/hooks/helper.ts +0 -70
  65. package/src/components/forms/src/hooks/useForm.ts +0 -130
  66. package/src/components/forms/src/hooks/useFormActions.ts +0 -63
  67. package/src/components/forms/src/hooks/useFormEvents.ts +0 -248
  68. package/src/components/forms/src/hooks/useFormValue.ts +0 -49
  69. package/src/components/forms/src/hooks/useFormValues.ts +0 -131
  70. package/src/components/forms/src/hooks/useLabelWidth.ts +0 -57
  71. package/src/components/forms/src/index.vue +0 -310
  72. package/src/components/forms/src/prop.ts +0 -80
  73. package/src/components/forms/src/types/form.type.ts +0 -275
  74. package/src/components/icons/index.less +0 -101
  75. package/src/components/icons/index.ts +0 -7
  76. package/src/components/icons/src/pick-icon.vue +0 -119
  77. package/src/components/icons/src/svg-icon.vue +0 -117
  78. package/src/components/iframe/index.less +0 -3
  79. package/src/components/iframe/index.ts +0 -5
  80. package/src/components/iframe/src/index.less +0 -3
  81. package/src/components/iframe/src/index.vue +0 -38
  82. package/src/components/index.ts +0 -53
  83. package/src/components/modal/index.less +0 -60
  84. package/src/components/modal/index.ts +0 -8
  85. package/src/components/modal/src/components/close-icon.vue +0 -46
  86. package/src/components/modal/src/components/modal-wrap.vue +0 -128
  87. package/src/components/modal/src/components/modal.tsx +0 -30
  88. package/src/components/modal/src/components/modalFooter.vue +0 -46
  89. package/src/components/modal/src/hooks/useDrag.ts +0 -107
  90. package/src/components/modal/src/hooks/useFullScreen.ts +0 -29
  91. package/src/components/modal/src/hooks/useModal.ts +0 -200
  92. package/src/components/modal/src/index.vue +0 -184
  93. package/src/components/modal/src/props.ts +0 -44
  94. package/src/components/modal/src/types/modal.type.ts +0 -30
  95. package/src/components/router/base-router.vue +0 -11
  96. package/src/components/router/index.ts +0 -3
  97. package/src/components/source/index.ts +0 -1
  98. package/src/components/source/src/hooks/useFetch.ts +0 -42
  99. package/src/components/source/src/hooks/usePage.ts +0 -3
  100. package/src/components/source/src/hooks/useSource.ts +0 -214
  101. package/src/components/source/src/index.ts +0 -5
  102. package/src/components/source/src/types/source.type.ts +0 -58
  103. package/src/components/source/src/types/table.type.ts +0 -8
  104. package/src/components/table/index.less +0 -179
  105. package/src/components/table/index.ts +0 -7
  106. package/src/components/table/src/components/TableActions.vue +0 -108
  107. package/src/components/table/src/components/TableHeader.vue +0 -78
  108. package/src/components/table/src/components/TableRender.vue +0 -76
  109. package/src/components/table/src/components/editable/CellComponent.ts +0 -57
  110. package/src/components/table/src/components/editable/EditTableCell.vue +0 -181
  111. package/src/components/table/src/components/editable/componentMap.ts +0 -18
  112. package/src/components/table/src/components/editable/index.ts +0 -58
  113. package/src/components/table/src/components/setting/Column.vue +0 -354
  114. package/src/components/table/src/components/setting/Download.vue +0 -55
  115. package/src/components/table/src/components/setting/Fullscreen.vue +0 -43
  116. package/src/components/table/src/components/setting/Size.vue +0 -42
  117. package/src/components/table/src/components/setting/index.vue +0 -64
  118. package/src/components/table/src/const.ts +0 -13
  119. package/src/components/table/src/hooks/useColumns.ts +0 -326
  120. package/src/components/table/src/hooks/useCustomRow.ts +0 -86
  121. package/src/components/table/src/hooks/useDataSource.ts +0 -97
  122. package/src/components/table/src/hooks/useHeaderCode.ts +0 -89
  123. package/src/components/table/src/hooks/useLoading.ts +0 -29
  124. package/src/components/table/src/hooks/usePagination.ts +0 -76
  125. package/src/components/table/src/hooks/useRowSelection.ts +0 -145
  126. package/src/components/table/src/hooks/useRows.ts +0 -30
  127. package/src/components/table/src/hooks/useTable.ts +0 -90
  128. package/src/components/table/src/hooks/useTableHeader.ts +0 -48
  129. package/src/components/table/src/hooks/useTableInstance.ts +0 -29
  130. package/src/components/table/src/hooks/useTableScroll.ts +0 -229
  131. package/src/components/table/src/index.vue +0 -212
  132. package/src/components/table/src/props.ts +0 -160
  133. package/src/components/table/src/types/table.type.ts +0 -160
  134. package/src/components/table/src/types/tableHeader.type.ts +0 -27
  135. package/src/components/tree/index.less +0 -41
  136. package/src/components/tree/index.ts +0 -5
  137. package/src/components/tree/src/components/TreeHeader.vue +0 -97
  138. package/src/components/tree/src/hooks/useTree.ts +0 -239
  139. package/src/components/tree/src/index.vue +0 -392
  140. package/src/components/tree/src/props.ts +0 -133
  141. package/src/components/tree/src/type/tree.ts +0 -105
  142. package/src/components/tree/src/utils/tree.ts +0 -73
  143. package/src/components/type.ts +0 -0
  144. package/src/components/upload/index.less +0 -35
  145. package/src/components/upload/index.ts +0 -5
  146. package/src/components/upload/src/helper.ts +0 -60
  147. package/src/components/upload/src/props.ts +0 -51
  148. package/src/components/upload/src/upload.vue +0 -191
  149. package/src/directives/icon.ts +0 -36
  150. package/src/directives/index.ts +0 -26
  151. package/src/directives/permission.ts +0 -20
  152. package/src/global.d.ts +0 -8
  153. package/src/index.ts +0 -4
  154. package/src/theme/content/index.vue +0 -37
  155. package/src/theme/feature/back-top.vue +0 -11
  156. package/src/theme/feature/index.vue +0 -7
  157. package/src/theme/footer/index.less +0 -16
  158. package/src/theme/footer/index.vue +0 -24
  159. package/src/theme/header/components/bread-crumb.vue +0 -26
  160. package/src/theme/header/components/fullscreen.vue +0 -12
  161. package/src/theme/header/components/handler.ts +0 -81
  162. package/src/theme/header/components/index.ts +0 -21
  163. package/src/theme/header/components/lang-picker.vue +0 -36
  164. package/src/theme/header/components/logo.vue +0 -35
  165. package/src/theme/header/components/menu-search.vue +0 -62
  166. package/src/theme/header/components/notify.vue +0 -22
  167. package/src/theme/header/components/setting-theme.vue +0 -123
  168. package/src/theme/header/components/theme-drawer/enum.ts +0 -12
  169. package/src/theme/header/components/theme-drawer/feature.vue +0 -75
  170. package/src/theme/header/components/theme-drawer/index.ts +0 -7
  171. package/src/theme/header/components/theme-drawer/menu-type.vue +0 -40
  172. package/src/theme/header/components/theme-drawer/select-item.vue +0 -46
  173. package/src/theme/header/components/theme-drawer/switch-item.vue +0 -39
  174. package/src/theme/header/components/theme-drawer/theme-color.vue +0 -26
  175. package/src/theme/header/components/trigger.vue +0 -14
  176. package/src/theme/header/components/user-info.vue +0 -60
  177. package/src/theme/header/const/index.ts +0 -40
  178. package/src/theme/header/helper/menu-tree.ts +0 -64
  179. package/src/theme/header/index.less +0 -442
  180. package/src/theme/header/index.ts +0 -0
  181. package/src/theme/header/index.vue +0 -96
  182. package/src/theme/header/multiple-header.vue +0 -67
  183. package/src/theme/header/set-theme.less +0 -68
  184. package/src/theme/index.ts +0 -3
  185. package/src/theme/sider/components/basic-menu/basic-menu-item.vue +0 -14
  186. package/src/theme/sider/components/basic-menu/basic-menu.vue +0 -122
  187. package/src/theme/sider/components/basic-menu/basic-sub-menu-item.vue +0 -46
  188. package/src/theme/sider/components/basic-menu/menu-item-content.vue +0 -13
  189. package/src/theme/sider/components/drag-bar.vue +0 -26
  190. package/src/theme/sider/components/layout-menu.vue +0 -132
  191. package/src/theme/sider/components/props.ts +0 -97
  192. package/src/theme/sider/components/sider-trigger.vue +0 -24
  193. package/src/theme/sider/helper/sider.ts +0 -52
  194. package/src/theme/sider/helper/split-menu.ts +0 -146
  195. package/src/theme/sider/hooks/useDragLine.ts +0 -86
  196. package/src/theme/sider/hooks/useOpenKeys.ts +0 -57
  197. package/src/theme/sider/index.less +0 -203
  198. package/src/theme/sider/index.vue +0 -88
  199. package/src/theme/tabs/components/TabContent.vue +0 -36
  200. package/src/theme/tabs/components/TabRedo.vue +0 -18
  201. package/src/theme/tabs/hooks/useMultifyTabs.ts +0 -96
  202. package/src/theme/tabs/hooks/useTabDropdown.ts +0 -89
  203. package/src/theme/tabs/index.less +0 -165
  204. package/src/theme/tabs/index.vue +0 -98
  205. package/src/theme/tabs/types/tabs.type.ts +0 -8
  206. package/src/theme/theme.less +0 -67
  207. package/src/theme/theme.vue +0 -90
  208. package/src/theme/transition.less +0 -99
@@ -1,7 +0,0 @@
1
- import MenuType from './menu-type.vue'
2
- import Feature from './feature.vue'
3
-
4
- export {
5
- MenuType,
6
- Feature
7
- }
@@ -1,40 +0,0 @@
1
- <template>
2
- <div class="dt-menu-type__wrap">
3
- <template v-for="item in menuTypeList" :key="item.title">
4
- <Tooltip :title="item.title" placement="bottom">
5
- <div
6
- @click="changeMenuType(item)"
7
- :class="[
8
- 'dt-menu-type__item',
9
- `dt-menu-type__item--${ item.type }`,
10
- {
11
- [`dt-menu-type__item--active`]: getMenuType === item.type && getMenuMode === item.mode
12
- }
13
- ]"
14
- >
15
- <div class="dt-sidebar-menu-type"></div>
16
- </div>
17
- </Tooltip>
18
- </template>
19
- </div>
20
- </template>
21
-
22
- <script lang="ts" setup>
23
- import { unref, ref } from 'vue'
24
- import { HandlerEnum, menuTypeList } from '../../const'
25
- import { useMenu } from '@dt-frames/core'
26
- import { Tooltip } from 'ant-design-vue'
27
- import { baseHandler } from '../handler';
28
-
29
-
30
- const { getMenuType, getMenuMode } = useMenu()
31
- const defMenuType = ref(unref(getMenuType))
32
-
33
- function changeMenuType(item) {
34
- // document.getElementsByTagName('html')[0].style.setProperty('--primary',color);
35
-
36
- defMenuType.value = item.type
37
-
38
- baseHandler(HandlerEnum.CHANGE_LAYOUT, item)
39
- }
40
- </script>
@@ -1,46 +0,0 @@
1
- <template>
2
- <div class="dt-feature-item">
3
- <span> {{ title }}</span>
4
- <Select
5
- v-bind="getBindValue"
6
- class="select-item"
7
- @change="handleChange"
8
- :disabled="disabled"
9
- size="small"
10
- :options="options"
11
- />
12
- </div>
13
- </template>
14
-
15
- <script lang="ts" setup>
16
- import { PropType, computed } from 'vue'
17
- import { Select } from 'ant-design-vue'
18
- import { HandlerEnum } from '../../const'
19
- import { baseHandler } from '../handler';
20
-
21
- type OptType = {
22
- label: string
23
- value: any
24
- [key: string]: string | number | boolean
25
- }
26
-
27
- const props = defineProps({
28
- event: { type: Number as PropType<HandlerEnum> },
29
- disabled: { type: Boolean },
30
- title: { type: String },
31
- def: { type: [String, Number] as PropType<string | number> },
32
- initValue: { type: [String, Number] as PropType<string | number> },
33
- options: {
34
- type: Array as PropType<OptType[]>,
35
- default: () => [],
36
- }
37
- })
38
-
39
- const getBindValue = computed(() => {
40
- return props.def ? { value: props.def, defaultValue: props.initValue || props.def } : {};
41
- })
42
-
43
- function handleChange(e) {
44
- props.event && baseHandler(props.event, e);
45
- }
46
- </script>
@@ -1,39 +0,0 @@
1
- <template>
2
- <div class="dt-feature-item">
3
- <span>{{ props.title }}</span>
4
- <Switch
5
- v-bind="getBindValue"
6
- :disabled="disabled"
7
- @change="handleChange"
8
- checkedChildren="开"
9
- unCheckedChildren="关"
10
- ></Switch>
11
- </div>
12
-
13
- </template>
14
-
15
- <script lang="ts" setup>
16
- import { Switch } from 'ant-design-vue'
17
- import { computed, PropType } from 'vue';
18
- import { HandlerEnum } from '../../const';
19
- import { baseHandler } from '../handler';
20
-
21
- const props = defineProps({
22
- event: {
23
- type: Number as PropType<HandlerEnum>
24
- },
25
- disabled: { type: Boolean },
26
- title: { type: String },
27
- def: {
28
- type: Boolean,
29
- }
30
- })
31
-
32
- const getBindValue = computed(() => {
33
- return props.def ? { checked: props.def } : {};
34
- })
35
-
36
- function handleChange(e) {
37
- props.event && baseHandler(props.event, e)
38
- }
39
- </script>
@@ -1,26 +0,0 @@
1
- <template>
2
- <div class="dt-theme-picker">
3
- <template>
4
-
5
- </template>
6
- </div>
7
-
8
- </template>
9
-
10
- <script lang="ts" setup>
11
- import { PropType } from 'vue';
12
- import { HandlerEnum } from '../../const';
13
-
14
- const props = defineProps({
15
- colorList: {
16
- type: Array as PropType<string[]>,
17
- default: []
18
- },
19
- event: {
20
- type: Number as PropType<HandlerEnum>
21
- },
22
- def: {
23
- type: String
24
- }
25
- })
26
- </script>
@@ -1,14 +0,0 @@
1
- <template>
2
- <div :class="['dt-header-trigger', props.theme]" @click="toggleCollapsed">
3
- <span v-if="getCollapsed" v-icon="'ic:baseline-format-indent-increase'"></span>
4
- <span v-else v-icon="'ic:baseline-format-indent-decrease'"></span>
5
- </div>
6
- </template>
7
-
8
- <script lang="ts" setup>
9
- import { useMenu } from '@dt-frames/core'
10
-
11
- const props = defineProps({ theme: String });
12
- const { getCollapsed, toggleCollapsed } = useMenu();
13
-
14
- </script>
@@ -1,60 +0,0 @@
1
- <template>
2
- <Popover placement="bottom" overlayClassName="user-info__popover" trigger="click">
3
- <template #content>
4
- <ul class="user-operate">
5
- <li v-for="it in getUserActions" @click="it.handleClick">
6
- <span v-icon="it.icon"></span>
7
- {{ it.label }}
8
- </li>
9
- <li>
10
- <span v-icon="'mdi:account-cog'"></span>
11
- 个人中心
12
- </li>
13
- <li>
14
- <span v-icon="'ic:baseline-key'"></span>
15
- 修改密码
16
- </li>
17
- <li class="border-bottom"></li>
18
- <li>
19
- <span v-icon="'ic:baseline-lock'"></span>
20
- 锁定屏幕
21
- </li>
22
- <li @click="signOut()">
23
- <span v-icon="'ant-design:logout-outlined'"></span>
24
- 退出系统
25
- </li>
26
- </ul>
27
- </template>
28
-
29
- <div class="userInfo">
30
- <Avatar :size="28" >
31
- <template #icon><img src="../../../assets/imgs/header/avatar.png" /></template>
32
- </Avatar>
33
- <span class="name">{{ getUserInfo?.userNo }}</span>
34
- </div>
35
- </Popover>
36
- </template>
37
-
38
- <script setup lang="ts">
39
- import { Popover, Avatar } from 'ant-design-vue';
40
- import { CacheKey, DtCache, useAppStore, useHeader, isObject, isFunction, useGo, Pages } from '@dt-frames/core'
41
-
42
- const getUserInfo = DtCache.getLocal(CacheKey.USER_INFO)
43
- const { getUserActions } = useHeader()
44
- const { appConf } = useAppStore()
45
- const go = useGo()
46
-
47
-
48
- // 退出系统
49
- function signOut() {
50
- if( isObject(appConf.pages?.ssoLogin) && appConf.pages.ssoLogin?.logout) {
51
- let redictUrl = isFunction(appConf.pages.ssoLogin.logout)
52
- ? appConf.pages.ssoLogin.logout()
53
- : appConf.pages.ssoLogin.logout
54
-
55
- location.href = redictUrl
56
- } else {
57
- go(Pages.LOGIN)
58
- }
59
- }
60
- </script>
@@ -1,40 +0,0 @@
1
- import { MenuMode, MenuType, Theme } from "@dt-frames/core";
2
-
3
- export const menuTypeList = [
4
- {
5
- title: '左侧菜单模式',
6
- headTheme: Theme.LIGHT,
7
- menuTheme: Theme.DARK,
8
- mode: MenuMode.INLINE,
9
- type: MenuType.SIDE,
10
- split: false
11
- },
12
- {
13
- title: '菜单混合模式',
14
- headTheme: Theme.DARK,
15
- menuTheme: Theme.LIGHT,
16
- mode: MenuMode.INLINE,
17
- type: MenuType.MIX,
18
- split: true
19
- },
20
- {
21
- title: '顶部菜单模式',
22
- headTheme: Theme.DARK,
23
- menuTheme: Theme.LIGHT,
24
- mode: MenuMode.HORIZONTAL,
25
- type: MenuType.TOP_MENU,
26
- split: false
27
- }
28
- ]
29
-
30
- export enum HandlerEnum {
31
- CHANGE_LAYOUT,
32
- SHOW_BREADCRUMB,
33
- SHOW_SEARCH,
34
- SHOW_NOTICY,
35
- SHOW_FULL_SCREEN,
36
- SHOW_LOCAL,
37
- SHOW_ROUTE_REUSE,
38
- SHOW_FOOTER,
39
- CONTENT_MODE
40
- }
@@ -1,64 +0,0 @@
1
- /** =====================================
2
- * 定义一些菜单操作的方法
3
- * =====================================*/
4
- import { CacheKey, DtCache, Menus, useAuthStore } from "@dt-frames/core";
5
- import { trim } from 'lodash-es'
6
-
7
- function deleteChildrenProp( menu: any ) {
8
- let obj = { ...menu };
9
- delete obj.children;
10
-
11
- return obj;
12
- }
13
-
14
- // 获取当前路由的面包屑
15
- export function getBreadCrumb(path: string, menus?: Menus[]) {
16
- const _menus = menus || DtCache.getLocal(CacheKey.MENUS)?.children || []
17
-
18
- let routes: Menus[] = []
19
-
20
- let getParentByPath = ( menu: any, path: string = '' ) => {
21
-
22
- if( menu.children && menu.children.length ) {
23
- menu.children.forEach( (subMenu: any) => {
24
- subMenu.parentMenus =
25
- [...menu.parentMenus]
26
- .concat( [ deleteChildrenProp( subMenu ) ] );
27
-
28
- getParentByPath( subMenu, path );
29
- } )
30
- }
31
-
32
- if( menu.url === path ) {
33
- routes = menu.parentMenus;
34
- }
35
- }
36
-
37
- _menus.forEach( (menu: any) => {
38
- menu.parentMenus = [ deleteChildrenProp( menu ) ];
39
-
40
- getParentByPath( menu, path );
41
- } );
42
-
43
- return routes;
44
- }
45
-
46
- export function getFilterMenu( filter: string = '', flag: boolean = false) {
47
- let _menus = [];
48
-
49
- if( !trim(filter) && !flag ) return _menus;
50
-
51
- let getTargetMenus = ( menusArr ) => {
52
- menusArr.forEach( menu => {
53
- if( menu.children && menu.children.length ) {
54
- getTargetMenus( menu.children );
55
- } else if( menu.label.indexOf( filter ) !== -1 || (flag && !trim(filter))){
56
- _menus.push( menu );
57
- }
58
- } )
59
- }
60
-
61
- getTargetMenus( DtCache.getLocal(CacheKey.MENUS)?.children );
62
-
63
- return _menus;
64
- }