ct-component-plus 0.0.42 → 0.0.43

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 (91) hide show
  1. package/package.json +36 -36
  2. package/packages/components/button/index.js +8 -8
  3. package/packages/components/button/src/button.vue +171 -171
  4. package/packages/components/cascader/index.js +7 -7
  5. package/packages/components/cascader/src/cascader.vue +247 -247
  6. package/packages/components/cascader/src/ct-cascader.vue +260 -260
  7. package/packages/components/cascader/src/index.js +50 -50
  8. package/packages/components/checkbox/index.js +7 -7
  9. package/packages/components/checkbox/src/checkbox.vue +51 -51
  10. package/packages/components/checkbox/src/index.js +12 -12
  11. package/packages/components/date-picker/index.js +8 -8
  12. package/packages/components/date-picker/src/clear-icon.vue +2 -2
  13. package/packages/components/date-picker/src/date-icon.vue +2 -2
  14. package/packages/components/date-picker/src/date-picker.vue +77 -77
  15. package/packages/components/date-picker/src/index.js +33 -33
  16. package/packages/components/dialog/index.js +8 -8
  17. package/packages/components/dialog/src/dialog.vue +103 -103
  18. package/packages/components/empty/index.js +8 -8
  19. package/packages/components/empty/src/empty.vue +97 -97
  20. package/packages/components/index.js +81 -81
  21. package/packages/components/input/index.js +7 -7
  22. package/packages/components/input/src/index.js +13 -13
  23. package/packages/components/input/src/input.vue +106 -106
  24. package/packages/components/input-range/index.js +7 -7
  25. package/packages/components/input-range/src/index.js +29 -29
  26. package/packages/components/input-range/src/input-range.vue +233 -233
  27. package/packages/components/loading/index.js +7 -7
  28. package/packages/components/loading/src/CtLoading.vue +74 -74
  29. package/packages/components/loading/src/beating.vue +71 -71
  30. package/packages/components/loading/src/progress.vue +120 -120
  31. package/packages/components/loading/src/spinner.vue +38 -38
  32. package/packages/components/menu/index.js +7 -7
  33. package/packages/components/menu/src/item.vue +46 -46
  34. package/packages/components/menu/src/link.vue +28 -28
  35. package/packages/components/menu/src/logo.vue +25 -25
  36. package/packages/components/menu/src/menu-item.vue +103 -103
  37. package/packages/components/menu/src/menu.vue +191 -191
  38. package/packages/components/menu/src/utils/index.js +4 -4
  39. package/packages/components/message/icon/ErrorIcon.vue +25 -25
  40. package/packages/components/message/icon/InfoIcon.vue +25 -25
  41. package/packages/components/message/icon/SuccessIcon.vue +25 -25
  42. package/packages/components/message/icon/WarningIcon.vue +25 -25
  43. package/packages/components/message/index.js +8 -8
  44. package/packages/components/message/src/method.js +54 -54
  45. package/packages/components/message-box/index.js +7 -7
  46. package/packages/components/message-box/src/message-box.vue +107 -107
  47. package/packages/components/page/index.js +7 -7
  48. package/packages/components/page/src/modules/DownloadButton.vue +21 -21
  49. package/packages/components/page/src/modules/TableTitle.vue +151 -151
  50. package/packages/components/page/src/page.vue +382 -382
  51. package/packages/components/pagination/index.js +7 -7
  52. package/packages/components/pagination/src/pagination.vue +36 -36
  53. package/packages/components/radio/index.js +7 -7
  54. package/packages/components/radio/src/index.js +12 -12
  55. package/packages/components/radio/src/radio.vue +47 -47
  56. package/packages/components/search-box/index.js +24 -24
  57. package/packages/components/search-box/src/index.js +29 -29
  58. package/packages/components/search-box/src/search-box.vue +250 -251
  59. package/packages/components/search-box/src/slot.vue +4 -4
  60. package/packages/components/select/index.js +7 -7
  61. package/packages/components/select/src/arrow-down.vue +2 -2
  62. package/packages/components/select/src/clear-icon.vue +2 -2
  63. package/packages/components/select/src/empty.vue +13 -13
  64. package/packages/components/select/src/index.js +51 -51
  65. package/packages/components/select/src/select.vue +380 -380
  66. package/packages/components/table/index.js +7 -7
  67. package/packages/components/table/src/TableSort.vue +179 -179
  68. package/packages/components/table/src/index.js +70 -66
  69. package/packages/components/table/src/table.vue +287 -287
  70. package/packages/components/tabs/index.js +7 -7
  71. package/packages/components/tabs/src/tabs.vue +225 -225
  72. package/packages/components/year-select/index.js +7 -7
  73. package/packages/components/year-select/src/index.js +44 -44
  74. package/packages/components/year-select/src/year-select.vue +273 -273
  75. package/packages/echarts/bar/index.js +63 -63
  76. package/packages/echarts/base.js +99 -99
  77. package/packages/echarts/line/index.js +106 -106
  78. package/packages/hooks/index.js +5 -5
  79. package/packages/hooks/use-buried/index.js +46 -46
  80. package/packages/hooks/use-checked-all/index.js +37 -37
  81. package/packages/hooks/use-echarts/index.js +1 -1
  82. package/packages/hooks/use-echarts/use-bar/index.js +72 -72
  83. package/packages/hooks/use-echarts/use-line/index.js +88 -88
  84. package/packages/hooks/use-namespace/index.js +65 -65
  85. package/packages/hooks/use-search-component/index.js +28 -28
  86. package/packages/style/element.less +725 -725
  87. package/packages/style/index.js +2 -2
  88. package/packages/style/init.less +114 -114
  89. package/packages/utils/index.js +1 -1
  90. package/packages/utils/operate.js +77 -77
  91. package/packages/utils/types.js +35 -35
@@ -1,47 +1,47 @@
1
- <template>
2
- <div :class="[ns.b()]">
3
- <span v-if="haveIcon" :class="[ns.e('icon')]">
4
- <slot name="icon" :menu="menu" :title="title">
5
- <ct-icon v-if="icon" :name="icon"></ct-icon>
6
- </slot>
7
- </span>
8
- <span :class="[ns.e('title')]">
9
- <slot name="title" :menu="menu" :title="title">
10
- {{ title }}
11
- </slot>
12
- </span>
13
- </div>
14
- </template>
15
-
16
- <script setup>
17
- import { computed } from "vue";
18
- import { useNamespace } from "../../../hooks";
19
- const props = defineProps({
20
- menu: {
21
- type: Object,
22
- default() {
23
- return {};
24
- },
25
- },
26
- icon: {
27
- type: String,
28
- default: "",
29
- },
30
- title: {
31
- type: String,
32
- default: "",
33
- },
34
- });
35
- const ns = useNamespace("menu-item");
36
- const haveIcon = computed(() => props.icon || props.menu.haveIcon);
37
- </script>
38
- <style lang='less'>
39
- .ct-menu-item {
40
- display: flex;
41
- align-items: center;
42
- &__icon {
43
- margin-right: var(--ct-menu-icon-margin);
44
- font-size: var(--ct-menu-icon-size);
45
- }
46
- }
1
+ <template>
2
+ <div :class="[ns.b()]">
3
+ <span v-if="haveIcon" :class="[ns.e('icon')]">
4
+ <slot name="icon" :menu="menu" :title="title">
5
+ <ct-icon v-if="icon" :name="icon"></ct-icon>
6
+ </slot>
7
+ </span>
8
+ <span :class="[ns.e('title')]">
9
+ <slot name="title" :menu="menu" :title="title">
10
+ {{ title }}
11
+ </slot>
12
+ </span>
13
+ </div>
14
+ </template>
15
+
16
+ <script setup>
17
+ import { computed } from "vue";
18
+ import { useNamespace } from "../../../hooks";
19
+ const props = defineProps({
20
+ menu: {
21
+ type: Object,
22
+ default() {
23
+ return {};
24
+ },
25
+ },
26
+ icon: {
27
+ type: String,
28
+ default: "",
29
+ },
30
+ title: {
31
+ type: String,
32
+ default: "",
33
+ },
34
+ });
35
+ const ns = useNamespace("menu-item");
36
+ const haveIcon = computed(() => props.icon || props.menu.haveIcon);
37
+ </script>
38
+ <style lang='less'>
39
+ .ct-menu-item {
40
+ display: flex;
41
+ align-items: center;
42
+ &__icon {
43
+ margin-right: var(--ct-menu-icon-margin);
44
+ font-size: var(--ct-menu-icon-size);
45
+ }
46
+ }
47
47
  </style>
@@ -1,29 +1,29 @@
1
- <template>
2
- <Component :is="type" v-bind="linkProps(to)">
3
- <slot></slot>
4
- </Component>
5
- </template>
6
-
7
- <script setup>
8
- const props = defineProps({
9
- to: {
10
- type: String,
11
- required: true,
12
- },
13
- type: {
14
- type: String,
15
- required: true,
16
- },
17
- });
18
- const linkProps = (to) => {
19
- if (props.type === "a") {
20
- return {
21
- href: to,
22
- target: "_blank",
23
- };
24
- }
25
- return {
26
- to: to,
27
- };
28
- };
1
+ <template>
2
+ <Component :is="type" v-bind="linkProps(to)">
3
+ <slot></slot>
4
+ </Component>
5
+ </template>
6
+
7
+ <script setup>
8
+ const props = defineProps({
9
+ to: {
10
+ type: String,
11
+ required: true,
12
+ },
13
+ type: {
14
+ type: String,
15
+ required: true,
16
+ },
17
+ });
18
+ const linkProps = (to) => {
19
+ if (props.type === "a") {
20
+ return {
21
+ href: to,
22
+ target: "_blank",
23
+ };
24
+ }
25
+ return {
26
+ to: to,
27
+ };
28
+ };
29
29
  </script>
@@ -1,26 +1,26 @@
1
- <template>
2
- <div :class="[ns.b(), ns.is('collapse', collapse)]">
3
- <img :class="ns.e('logo')" src="" alt="" />
4
- <span :class="ns.e('title')"></span>
5
- </div>
6
- </template>
7
-
8
- <script setup>
9
- import { reactive, onMounted } from "vue";
10
- import { useNamespace } from "../../../hooks";
11
- const props = defineProps({
12
- collapse: {
13
- type: Boolean,
14
- default: false,
15
- },
16
- title: {
17
- type: String,
18
- default: "",
19
- },
20
- });
21
- const ns = useNamespace("logo");
22
- const state = reactive({});
23
- onMounted(() => {});
24
- </script>
25
- <style lang='less'>
1
+ <template>
2
+ <div :class="[ns.b(), ns.is('collapse', collapse)]">
3
+ <img :class="ns.e('logo')" src="" alt="" />
4
+ <span :class="ns.e('title')"></span>
5
+ </div>
6
+ </template>
7
+
8
+ <script setup>
9
+ import { reactive, onMounted } from "vue";
10
+ import { useNamespace } from "../../../hooks";
11
+ const props = defineProps({
12
+ collapse: {
13
+ type: Boolean,
14
+ default: false,
15
+ },
16
+ title: {
17
+ type: String,
18
+ default: "",
19
+ },
20
+ });
21
+ const ns = useNamespace("logo");
22
+ const state = reactive({});
23
+ onMounted(() => {});
24
+ </script>
25
+ <style lang='less'>
26
26
  </style>
@@ -1,104 +1,104 @@
1
- <template>
2
- <template v-if="isLastOne">
3
- <app-link :to="routerLink" :type="linkType" @click="clickLinkMenu(menu)">
4
- <el-tooltip
5
- :disabled="!collapse && menu.label.length <= 10"
6
- effect="dark"
7
- :content="menu.label"
8
- placement="right"
9
- >
10
- <el-menu-item :index="menuIndex" class="ct-menu-item">
11
- <i v-if="haveIcon" class="ct-menu-item__icon">
12
- <slot name="icon" :menu="menu" :title="menu.label"> </slot>
13
- </i>
14
- <template #title>
15
- <slot name="title" :menu="menu" :title="menu.label">
16
- {{ menu.label }}
17
- </slot>
18
- </template>
19
- </el-menu-item>
20
- </el-tooltip>
21
- </app-link>
22
- </template>
23
- <el-sub-menu v-else :index="menuIndex" popper-class="ct-menu">
24
- <template #title>
25
- <i class="ct-menu-item__icon">
26
- <slot name="icon" :menu="menu" :title="menu.label"></slot>
27
- </i>
28
- <span>
29
- <slot name="title" :menu="menu" :title="menu.label">
30
- {{ menu.label }}
31
- </slot>
32
- </span>
33
- </template>
34
- <menu-item
35
- v-for="child in menu.children"
36
- :key="child.router || child.value"
37
- :menu="child"
38
- :is-nest="true"
39
- class="is-nest-menu"
40
- @clickMenu="clickLinkMenu"
41
- >
42
- <template #icon="{ menu }">
43
- <slot name="icon" :menu="menu">
44
- <ct-icon v-if="menu.icon" :name="menu.icon"></ct-icon>
45
- </slot>
46
- </template>
47
- <template #title="{ menu }">
48
- <slot name="title" :menu="menu"> {{ menu.label }} </slot>
49
- </template>
50
- </menu-item>
51
- </el-sub-menu>
52
- </template>
53
-
54
- <script setup>
55
- import { onMounted, computed } from "vue";
56
- import appLink from "./link.vue";
57
- import { getMenuIndex } from "./utils";
58
- const props = defineProps({
59
- menu: {
60
- type: Object,
61
- default() {
62
- return {};
63
- },
64
- },
65
- isNest: {
66
- type: Boolean,
67
- default: false,
68
- },
69
- collapse: Boolean,
70
- });
71
- const emit = defineEmits(["clickMenu"]);
72
- const isLastOne = computed(() => {
73
- const item = props.menu;
74
- return !item.children || !item.children.length;
75
- });
76
- const menuIndex = computed(() => {
77
- return getMenuIndex(props.menu);
78
- });
79
- const routerLink = computed(() => {
80
- return props.menu.outLink || props.menu.router;
81
- });
82
- const linkType = computed(() => {
83
- //判断跳转链接的方式是a标签还是router-link
84
- if (props.menu.linkType) return props.menu.linkType;
85
- let type = "router-link";
86
- if (props.menu.outLink) type = "a";
87
- return type;
88
- });
89
- const haveIcon = computed(() => props.menu.icon || props.menu.haveIcon);
90
- const clickLinkMenu = (menu) => {
91
- emit("clickMenu", menu);
92
- };
93
- onMounted(() => {});
94
- </script>
95
- <style lang='less'>
96
- .ct-menu-item {
97
- display: flex;
98
- align-items: center;
99
- &__icon {
100
- margin-right: var(--ct-menu-icon-margin);
101
- font-size: var(--ct-menu-icon-size);
102
- }
103
- }
1
+ <template>
2
+ <template v-if="isLastOne">
3
+ <app-link :to="routerLink" :type="linkType" @click="clickLinkMenu(menu)">
4
+ <el-tooltip
5
+ :disabled="!collapse && menu.label.length <= 10"
6
+ effect="dark"
7
+ :content="menu.label"
8
+ placement="right"
9
+ >
10
+ <el-menu-item :index="menuIndex" class="ct-menu-item">
11
+ <i v-if="haveIcon" class="ct-menu-item__icon">
12
+ <slot name="icon" :menu="menu" :title="menu.label"> </slot>
13
+ </i>
14
+ <template #title>
15
+ <slot name="title" :menu="menu" :title="menu.label">
16
+ {{ menu.label }}
17
+ </slot>
18
+ </template>
19
+ </el-menu-item>
20
+ </el-tooltip>
21
+ </app-link>
22
+ </template>
23
+ <el-sub-menu v-else :index="menuIndex" popper-class="ct-menu">
24
+ <template #title>
25
+ <i class="ct-menu-item__icon">
26
+ <slot name="icon" :menu="menu" :title="menu.label"></slot>
27
+ </i>
28
+ <span>
29
+ <slot name="title" :menu="menu" :title="menu.label">
30
+ {{ menu.label }}
31
+ </slot>
32
+ </span>
33
+ </template>
34
+ <menu-item
35
+ v-for="child in menu.children"
36
+ :key="child.router || child.value"
37
+ :menu="child"
38
+ :is-nest="true"
39
+ class="is-nest-menu"
40
+ @clickMenu="clickLinkMenu"
41
+ >
42
+ <template #icon="{ menu }">
43
+ <slot name="icon" :menu="menu">
44
+ <ct-icon v-if="menu.icon" :name="menu.icon"></ct-icon>
45
+ </slot>
46
+ </template>
47
+ <template #title="{ menu }">
48
+ <slot name="title" :menu="menu"> {{ menu.label }} </slot>
49
+ </template>
50
+ </menu-item>
51
+ </el-sub-menu>
52
+ </template>
53
+
54
+ <script setup>
55
+ import { onMounted, computed } from "vue";
56
+ import appLink from "./link.vue";
57
+ import { getMenuIndex } from "./utils";
58
+ const props = defineProps({
59
+ menu: {
60
+ type: Object,
61
+ default() {
62
+ return {};
63
+ },
64
+ },
65
+ isNest: {
66
+ type: Boolean,
67
+ default: false,
68
+ },
69
+ collapse: Boolean,
70
+ });
71
+ const emit = defineEmits(["clickMenu"]);
72
+ const isLastOne = computed(() => {
73
+ const item = props.menu;
74
+ return !item.children || !item.children.length;
75
+ });
76
+ const menuIndex = computed(() => {
77
+ return getMenuIndex(props.menu);
78
+ });
79
+ const routerLink = computed(() => {
80
+ return props.menu.outLink || props.menu.router;
81
+ });
82
+ const linkType = computed(() => {
83
+ //判断跳转链接的方式是a标签还是router-link
84
+ if (props.menu.linkType) return props.menu.linkType;
85
+ let type = "router-link";
86
+ if (props.menu.outLink) type = "a";
87
+ return type;
88
+ });
89
+ const haveIcon = computed(() => props.menu.icon || props.menu.haveIcon);
90
+ const clickLinkMenu = (menu) => {
91
+ emit("clickMenu", menu);
92
+ };
93
+ onMounted(() => {});
94
+ </script>
95
+ <style lang='less'>
96
+ .ct-menu-item {
97
+ display: flex;
98
+ align-items: center;
99
+ &__icon {
100
+ margin-right: var(--ct-menu-icon-margin);
101
+ font-size: var(--ct-menu-icon-size);
102
+ }
103
+ }
104
104
  </style>