vdesign-ui 0.2.19 → 0.3.0

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 (168) hide show
  1. package/README.md +58 -58
  2. package/dist/components/actionbar/index.js +8 -8
  3. package/dist/components/actionbar/index.vue +39 -39
  4. package/dist/components/actionbar/style.less +44 -44
  5. package/dist/components/actionbar-cell/index.js +7 -7
  6. package/dist/components/actionbar-cell/index.vue +42 -42
  7. package/dist/components/actions/index.js +6 -6
  8. package/dist/components/actions/index.vue +77 -77
  9. package/dist/components/actions/style.less +109 -109
  10. package/dist/components/actions-cell/index.js +6 -6
  11. package/dist/components/actions-cell/index.vue +94 -94
  12. package/dist/components/actions-cell/style.less +38 -38
  13. package/dist/components/activityviews/index.js +8 -8
  14. package/dist/components/activityviews/index.vue +192 -192
  15. package/dist/components/activityviews/style.less +161 -161
  16. package/dist/components/badge/index.js +8 -8
  17. package/dist/components/badge/index.vue +49 -49
  18. package/dist/components/badge/style.less +54 -54
  19. package/dist/components/button/index.js +8 -8
  20. package/dist/components/button/index.vue +93 -93
  21. package/dist/components/button/style.less +558 -558
  22. package/dist/components/calendar/index-element.vue +84 -84
  23. package/dist/components/calendar/index.js +7 -7
  24. package/dist/components/calendar/index.vue +53 -53
  25. package/dist/components/calendar/style.less +138 -138
  26. package/dist/components/checkbox/index.js +8 -8
  27. package/dist/components/checkbox/index.vue +161 -161
  28. package/dist/components/checkbox/style.less +288 -288
  29. package/dist/components/checkbox-group/index.js +7 -7
  30. package/dist/components/checkbox-group/index.vue +73 -73
  31. package/dist/components/common/state/index.vue +33 -33
  32. package/dist/components/common/state/style.less +47 -47
  33. package/dist/components/data-list/index.js +10 -10
  34. package/dist/components/data-list/index.vue +19 -19
  35. package/dist/components/data-list/style.less +623 -623
  36. package/dist/components/datetime-picker/index.js +7 -7
  37. package/dist/components/datetime-picker/index.vue +39 -39
  38. package/dist/components/datetime-picker/style.less +23 -23
  39. package/dist/components/dialog/index.js +8 -8
  40. package/dist/components/dialog/index.vue +164 -164
  41. package/dist/components/dialog/overlay-manager.js +18 -18
  42. package/dist/components/dialog/style.less +138 -138
  43. package/dist/components/divider/index.js +8 -8
  44. package/dist/components/divider/index.vue +54 -54
  45. package/dist/components/divider/style.less +92 -92
  46. package/dist/components/dropdown/index.js +8 -8
  47. package/dist/components/dropdown/index.vue +218 -218
  48. package/dist/components/dropdown/style.less +432 -432
  49. package/dist/components/empty/index.js +8 -8
  50. package/dist/components/empty/index.vue +138 -138
  51. package/dist/components/empty/style.less +60 -60
  52. package/dist/components/footer/index.js +6 -6
  53. package/dist/components/footer/index.vue +33 -33
  54. package/dist/components/footer/style.less +20 -20
  55. package/dist/components/footnav/index.js +6 -6
  56. package/dist/components/footnav/index.vue +93 -93
  57. package/dist/components/footnav/style.less +22 -22
  58. package/dist/components/footnav-item/index.js +6 -6
  59. package/dist/components/footnav-item/index.vue +50 -50
  60. package/dist/components/footnav-item/style.less +39 -39
  61. package/dist/components/form/index.js +6 -6
  62. package/dist/components/form/index.vue +14 -14
  63. package/dist/components/headnav/index.js +6 -6
  64. package/dist/components/headnav/index.vue +185 -185
  65. package/dist/components/headnav/style.less +231 -231
  66. package/dist/components/icon/font/iconfont.css +163 -163
  67. package/dist/components/icon/font/iconfont.js +5 -5
  68. package/dist/components/icon/index.js +9 -9
  69. package/dist/components/icon/index.vue +96 -96
  70. package/dist/components/icon/style.less +44 -44
  71. package/dist/components/input/calcTextareaHeight.js +162 -162
  72. package/dist/components/input/index.js +8 -8
  73. package/dist/components/input/index.vue +345 -345
  74. package/dist/components/input/style.less +471 -471
  75. package/dist/components/list/index.js +8 -8
  76. package/dist/components/list/index.vue +152 -152
  77. package/dist/components/list/style.less +213 -213
  78. package/dist/components/loading/index.js +6 -6
  79. package/dist/components/loading/index.vue +68 -68
  80. package/dist/components/loading/style.less +53 -53
  81. package/dist/components/mixins/clickoutside.js +81 -81
  82. package/dist/components/mixins/dom.js +41 -41
  83. package/dist/components/mixins/languageMixin.js +43 -41
  84. package/dist/components/mixins/outlineConfigPlugin.js +45 -45
  85. package/dist/components/mixins/router-link.js +22 -22
  86. package/dist/components/mixins/themeMixin.js +43 -43
  87. package/dist/components/noticebar/index.js +8 -8
  88. package/dist/components/noticebar/index.vue +258 -258
  89. package/dist/components/noticebar/style.less +333 -328
  90. package/dist/components/overlay/index.js +8 -8
  91. package/dist/components/overlay/index.vue +184 -184
  92. package/dist/components/overlay/style.less +24 -24
  93. package/dist/components/pagebreak/index.js +6 -6
  94. package/dist/components/pagebreak/index.vue +67 -67
  95. package/dist/components/pagebreak/style.less +41 -41
  96. package/dist/components/password/index.js +8 -8
  97. package/dist/components/password/index.vue +64 -64
  98. package/dist/components/popover/index.js +8 -8
  99. package/dist/components/popover/index.vue +100 -100
  100. package/dist/components/popover/style.less +346 -346
  101. package/dist/components/popover/vue-popover.vue +314 -314
  102. package/dist/components/popup/index.js +7 -7
  103. package/dist/components/popup/index.vue +165 -165
  104. package/dist/components/popup/style.less +78 -78
  105. package/dist/components/radio/index.js +8 -8
  106. package/dist/components/radio/index.vue +184 -184
  107. package/dist/components/radio/style.less +300 -300
  108. package/dist/components/radio-group/index.js +7 -7
  109. package/dist/components/radio-group/index.vue +62 -62
  110. package/dist/components/result/index.js +8 -8
  111. package/dist/components/result/index.vue +73 -73
  112. package/dist/components/result/style.less +43 -43
  113. package/dist/components/search/index.js +8 -8
  114. package/dist/components/search/index.vue +70 -70
  115. package/dist/components/selector/index.js +8 -8
  116. package/dist/components/selector/index.vue +161 -161
  117. package/dist/components/selector/style.less +484 -484
  118. package/dist/components/skeleton/index.js +6 -6
  119. package/dist/components/skeleton/index.vue +207 -207
  120. package/dist/components/skeleton/style.less +196 -196
  121. package/dist/components/slider/draggable.js +49 -49
  122. package/dist/components/slider/index.js +6 -6
  123. package/dist/components/slider/index.vue +167 -167
  124. package/dist/components/slider/style.less +99 -99
  125. package/dist/components/slider/utils.js +59 -59
  126. package/dist/components/step/index.js +7 -7
  127. package/dist/components/step/index.vue +48 -48
  128. package/dist/components/step/style.less +66 -66
  129. package/dist/components/step-item/index.js +7 -7
  130. package/dist/components/step-item/index.vue +126 -126
  131. package/dist/components/step-item/style.less +399 -399
  132. package/dist/components/stepper/index.js +8 -8
  133. package/dist/components/stepper/index.vue +150 -150
  134. package/dist/components/style/index.vue +42 -42
  135. package/dist/components/switch/index.js +8 -8
  136. package/dist/components/switch/index.vue +72 -72
  137. package/dist/components/switch/style.less +56 -56
  138. package/dist/components/tab/index.js +7 -7
  139. package/dist/components/tab/index.vue +97 -97
  140. package/dist/components/tabs/index.js +8 -8
  141. package/dist/components/tabs/index.vue +356 -348
  142. package/dist/components/tabs/style.less +504 -493
  143. package/dist/components/tag/index.js +6 -6
  144. package/dist/components/tag/index.vue +64 -64
  145. package/dist/components/tag/style.less +210 -210
  146. package/dist/components/title/index.js +8 -8
  147. package/dist/components/title/index.vue +99 -99
  148. package/dist/components/title/style.less +187 -187
  149. package/dist/components/toast/index.js +139 -97
  150. package/dist/components/toast/index.vue +50 -49
  151. package/dist/components/toast/style.less +58 -57
  152. package/dist/components/transition/index.js +8 -8
  153. package/dist/components/transition/index.vue +13 -13
  154. package/dist/components/transition/style.less +208 -208
  155. package/dist/components/upload/index.js +6 -6
  156. package/dist/components/upload/index.vue +106 -106
  157. package/dist/components/upload/style.less +147 -147
  158. package/dist/components/utils/assist.js +34 -34
  159. package/dist/components/utils/env.js +21 -21
  160. package/dist/locale/ar.js +97 -97
  161. package/dist/locale/en.js +97 -97
  162. package/dist/locale/zh.js +97 -97
  163. package/dist/token.css +9 -9
  164. package/dist/vdesign-ui.common.js +212 -161
  165. package/dist/vdesign-ui.css +1 -1
  166. package/dist/vdesign-ui.umd.js +212 -161
  167. package/dist/vdesign-ui.umd.min.js +2 -2
  168. package/package.json +113 -113
@@ -1,8 +1,8 @@
1
- import HdDatetimePicker from './index.vue';
2
- import './style.less';
3
-
4
- HdDatetimePicker.install = function (Vue) {
5
- Vue.component(HdDatetimePicker.name, HdDatetimePicker);
6
- };
7
-
1
+ import HdDatetimePicker from './index.vue';
2
+ import './style.less';
3
+
4
+ HdDatetimePicker.install = function (Vue) {
5
+ Vue.component(HdDatetimePicker.name, HdDatetimePicker);
6
+ };
7
+
8
8
  export default HdDatetimePicker;
@@ -1,39 +1,39 @@
1
- <template>
2
- <van-datetime-picker v-if="!picker" class="vd-datetime-picker" v-on="$listeners" v-bind="$attrs" />
3
- <van-picker v-else class="vd-datetime-picker" v-on="$listeners" v-bind="$attrs" />
4
- </template>
5
-
6
- <script>
7
- // import Vue from 'vue'
8
- import { DatetimePicker } from 'vant';
9
- import { Picker } from 'vant';
10
- // import 'vant/lib/datetime-picker/style';
11
- // import 'vant/lib/picker/style';
12
-
13
-
14
- // Vue.use(Picker);
15
- // Vue.use(DatetimePicker)
16
-
17
-
18
- export default {
19
- name: 'vd-datetime-picker',
20
- components: {
21
- 'van-picker': Picker,
22
- 'van-datetime-picker': DatetimePicker
23
- },
24
- props: {
25
- picker: {
26
- type: Boolean,
27
- default: false,
28
- }
29
- },
30
- data() {
31
- return {
32
- };
33
- },
34
- };
35
- </script>
36
-
37
- <style lang="less">
38
- @import './style.less';
39
- </style>
1
+ <template>
2
+ <van-datetime-picker v-if="!picker" class="vd-datetime-picker" v-on="$listeners" v-bind="$attrs" />
3
+ <van-picker v-else class="vd-datetime-picker" v-on="$listeners" v-bind="$attrs" />
4
+ </template>
5
+
6
+ <script>
7
+ // import Vue from 'vue'
8
+ import { DatetimePicker } from 'vant';
9
+ import { Picker } from 'vant';
10
+ // import 'vant/lib/datetime-picker/style';
11
+ // import 'vant/lib/picker/style';
12
+
13
+
14
+ // Vue.use(Picker);
15
+ // Vue.use(DatetimePicker)
16
+
17
+
18
+ export default {
19
+ name: 'vd-datetime-picker',
20
+ components: {
21
+ 'van-picker': Picker,
22
+ 'van-datetime-picker': DatetimePicker
23
+ },
24
+ props: {
25
+ picker: {
26
+ type: Boolean,
27
+ default: false,
28
+ }
29
+ },
30
+ data() {
31
+ return {
32
+ };
33
+ },
34
+ };
35
+ </script>
36
+
37
+ <style lang="less">
38
+ @import './style.less';
39
+ </style>
@@ -1,24 +1,24 @@
1
- .vd-datetime-picker {
2
-
3
- .van-picker__columns {
4
- padding: 0 var(--spacing-datepicker-padding_y);
5
- }
6
-
7
- .van-picker-column__item {
8
- height: var(--height-datepicker-roll_bg);
9
- font-size: var(--en-single-f-d-s-fontSize);
10
- font-weight: var(--en-single-f-d-s-fontWeight);
11
- color: var(--color-datepicker-date-text-disable);
12
-
13
- &--selected {
14
- font-size: var(--en-single-f-e-s-fontSize);
15
- font-weight: var(--en-single-f-e-s-fontWeight);
16
- color: var(--color-datepicker-date-text-default);
17
- }
18
- }
19
-
20
- .van-picker__frame {
21
- background: var(--color-datepicker-date_mask-bg-active);
22
- border-radius: var(--radius-datepicker-roll_bg);
23
- }
1
+ .vd-datetime-picker {
2
+
3
+ .van-picker__columns {
4
+ padding: 0 var(--spacing-datepicker-padding_y);
5
+ }
6
+
7
+ .van-picker-column__item {
8
+ height: var(--height-datepicker-roll_bg);
9
+ font-size: var(--en-single-f-d-s-fontSize);
10
+ font-weight: var(--en-single-f-d-s-fontWeight);
11
+ color: var(--color-datepicker-date-text-disable);
12
+
13
+ &--selected {
14
+ font-size: var(--en-single-f-e-s-fontSize);
15
+ font-weight: var(--en-single-f-e-s-fontWeight);
16
+ color: var(--color-datepicker-date-text-default);
17
+ }
18
+ }
19
+
20
+ .van-picker__frame {
21
+ background: var(--color-datepicker-date_mask-bg-active);
22
+ border-radius: var(--radius-datepicker-roll_bg);
23
+ }
24
24
  }
@@ -1,8 +1,8 @@
1
- import Dialog from './index.vue';
2
- import './style.less';
3
-
4
- Dialog.install = function (Vue) {
5
- Vue.component(Dialog.name, Dialog);
6
- };
7
-
8
- export default Dialog;
1
+ import Dialog from './index.vue';
2
+ import './style.less';
3
+
4
+ Dialog.install = function (Vue) {
5
+ Vue.component(Dialog.name, Dialog);
6
+ };
7
+
8
+ export default Dialog;
@@ -1,164 +1,164 @@
1
- <template>
2
- <div class="vd-dialog-wrap">
3
- <div class="vd-dialog__overlay" v-if="visible && isOverlayVisible && overlay" :style="{ zIndex: overlayZIndex }"
4
- @click="handleOverlayClick"></div>
5
- <transition name="vd-dialog-fade">
6
- <div class="vd-dialog" v-if="visible" :class="computedClassName" :style="{width : width, zIndex: overlayZIndex + 1}">
7
- <header class="vd-dialog__header" :class="{ 'vd-dialog__header--img': $slots.imgs }">
8
- <div class="vd-dialog__header--img-content" v-if="$slots.imgs">
9
- <slot name="imgs"></slot>
10
- </div>
11
- <div class="vd-dialog__title" v-if="title || $slots.title">
12
- <slot name="title">
13
- {{ title }}
14
- </slot>
15
- </div>
16
- </header>
17
- <div class="vd-dialog__content">
18
- <div class="vd-dialog__message" :class="{ 'vd-dialog__message--head': !title }"
19
- v-if="message || $slots.content">
20
- <slot name="content">{{message}}</slot>
21
- </div>
22
- </div>
23
- <footer class="vd-dialog__footer">
24
- <div class="vd-dialog__btns" v-if="btns">
25
- <vd-button type="tertiary_grey" size="large" @click="cancel">{{ cancelButtonText ||
26
- $t("alert.cancel") }}</vd-button>
27
- <vd-button type="large" @click="confirm">{{ confirmButtonText || $t("alert.confirm") }} </vd-button>
28
- </div>
29
- <div class="vd-dialog__btn" v-if="btn">
30
- <vd-button type="large" @click="confirm" block>{{ confirmButtonText || $t("alert.confirm")
31
- }}</vd-button>
32
- </div>
33
- <div class="vd-dialog__btns--text" v-if="btnsText">
34
- <vd-button type="tertiary_text" size="large" @click="cancel">{{ cancelButtonText ||
35
- $t("alert.cancel")
36
- }}</vd-button>
37
- <vd-button type="primary_text" size="large" @click="confirm">{{ confirmButtonText ||
38
- $t("alert.confirm") }}</vd-button>
39
- </div>
40
- <div class="vd-dialog__btn--text-block" v-if="btnTextBlock">
41
- <vd-button type="primary_text" size="large" block @click="confirm">{{ confirmButtonText ||
42
- $t("alert.confirm") }}</vd-button>
43
- </div>
44
- <div class="vd-dialog__btns-block" v-if="btnsBlock">
45
- <vd-button type="primary" block size="large" @click="confirm">{{ confirmButtonText ||
46
- $t("alert.confirm") }}</vd-button>
47
- <vd-button type="primary_text" block size="large" @click="cancel">{{ cancelButtonText ||
48
- $t("alert.cancel") }}</vd-button>
49
- </div>
50
- <div class="vd-dialog__btns--text" v-if="$slots['extra-btn']">
51
- <slot name="extra-btn"></slot>
52
- </div>
53
- </footer>
54
- </div>
55
- </transition>
56
- </div>
57
- </template>
58
-
59
- <script>
60
-
61
- import { OverlayManager } from './overlay-manager.js';
62
- import VdButton from '../button';
63
-
64
- export default {
65
- name: 'vd-dialog',
66
- components: {
67
- VdButton
68
- },
69
- props: {
70
- value: Boolean,
71
- btns: Boolean,
72
- btnsBlock: Boolean,
73
- btn: Boolean,
74
- btnsText: Boolean,
75
- btnTextBlock: Boolean,
76
- message: String,
77
- title: String,
78
- className: String,
79
- overlay: {
80
- type: Boolean,
81
- default: true
82
- },
83
- confirmButtonText: String,
84
- cancelButtonText: String,
85
- closeOnOverlay: {
86
- type: Boolean,
87
- default: true
88
- },
89
- width: [Number, String],
90
- },
91
- data() {
92
- return {
93
- isOverlayVisible: false,
94
- overlayZIndex: 2000
95
- }
96
- },
97
- watch: {
98
- visible: {
99
- immediate: true,
100
- handler(val) {
101
- if (val) {
102
- this.showOverlayLayer();
103
- } else {
104
- this.hideOverlayLayer();
105
- }
106
- },
107
- },
108
- },
109
- computed: {
110
- visible() {
111
- return this.value
112
- },
113
- computedClassName() {
114
- return this.className ? `vd-dialog--${this.className}` : '';
115
- },
116
- },
117
- methods: {
118
- showOverlayLayer() {
119
- if (this.overlay) {
120
- OverlayManager.increment();
121
- this.isOverlayVisible = OverlayManager.isOverlayVisible();
122
- this.overlayZIndex = OverlayManager.getZIndex();
123
- }
124
- },
125
- hideOverlayLayer() {
126
- if (this.overlay) {
127
- OverlayManager.decrement();
128
- this.isOverlayVisible = OverlayManager.isOverlayVisible();
129
- this.overlayZIndex = OverlayManager.getZIndex(); // 更新 z-index,以便其他遮罩正确显示
130
- }
131
- },
132
- handleOverlayClick() {
133
- if (this.closeOnOverlay) {
134
- this.closeDialog();
135
- }
136
- },
137
- closeDialog() {
138
- this.$emit('input', false);
139
- },
140
- cancel() {
141
- this.closeDialog();
142
- this.$emit('cancel');
143
- },
144
- confirm() {
145
- this.closeDialog();
146
- this.$emit('confirm');
147
- },
148
- },
149
- mounted() {
150
- if (this.visible) {
151
- this.showOverlayLayer();
152
- }
153
- },
154
- beforeDestroy() {
155
- if (this.visible) {
156
- this.hideOverlayLayer();
157
- }
158
- }
159
- }
160
- </script>
161
-
162
- <style lang="less">
163
- @import './style.less';
164
- </style>
1
+ <template>
2
+ <div class="vd-dialog-wrap">
3
+ <div class="vd-dialog__overlay" v-if="visible && isOverlayVisible && overlay" :style="{ zIndex: overlayZIndex }"
4
+ @click="handleOverlayClick"></div>
5
+ <transition name="vd-dialog-fade">
6
+ <div class="vd-dialog" v-if="visible" :class="computedClassName" :style="{width : width, zIndex: overlayZIndex + 1}">
7
+ <header class="vd-dialog__header" :class="{ 'vd-dialog__header--img': $slots.imgs }">
8
+ <div class="vd-dialog__header--img-content" v-if="$slots.imgs">
9
+ <slot name="imgs"></slot>
10
+ </div>
11
+ <div class="vd-dialog__title" v-if="title || $slots.title">
12
+ <slot name="title">
13
+ {{ title }}
14
+ </slot>
15
+ </div>
16
+ </header>
17
+ <div class="vd-dialog__content">
18
+ <div class="vd-dialog__message" :class="{ 'vd-dialog__message--head': !title }"
19
+ v-if="message || $slots.content">
20
+ <slot name="content">{{message}}</slot>
21
+ </div>
22
+ </div>
23
+ <footer class="vd-dialog__footer">
24
+ <div class="vd-dialog__btns" v-if="btns">
25
+ <vd-button type="tertiary_grey" size="large" @click="cancel">{{ cancelButtonText ||
26
+ $t("alert.cancel") }}</vd-button>
27
+ <vd-button type="large" @click="confirm">{{ confirmButtonText || $t("alert.confirm") }} </vd-button>
28
+ </div>
29
+ <div class="vd-dialog__btn" v-if="btn">
30
+ <vd-button type="large" @click="confirm" block>{{ confirmButtonText || $t("alert.confirm")
31
+ }}</vd-button>
32
+ </div>
33
+ <div class="vd-dialog__btns--text" v-if="btnsText">
34
+ <vd-button type="tertiary_text" size="large" @click="cancel">{{ cancelButtonText ||
35
+ $t("alert.cancel")
36
+ }}</vd-button>
37
+ <vd-button type="primary_text" size="large" @click="confirm">{{ confirmButtonText ||
38
+ $t("alert.confirm") }}</vd-button>
39
+ </div>
40
+ <div class="vd-dialog__btn--text-block" v-if="btnTextBlock">
41
+ <vd-button type="primary_text" size="large" block @click="confirm">{{ confirmButtonText ||
42
+ $t("alert.confirm") }}</vd-button>
43
+ </div>
44
+ <div class="vd-dialog__btns-block" v-if="btnsBlock">
45
+ <vd-button type="primary" block size="large" @click="confirm">{{ confirmButtonText ||
46
+ $t("alert.confirm") }}</vd-button>
47
+ <vd-button type="primary_text" block size="large" @click="cancel">{{ cancelButtonText ||
48
+ $t("alert.cancel") }}</vd-button>
49
+ </div>
50
+ <div class="vd-dialog__btns--text" v-if="$slots['extra-btn']">
51
+ <slot name="extra-btn"></slot>
52
+ </div>
53
+ </footer>
54
+ </div>
55
+ </transition>
56
+ </div>
57
+ </template>
58
+
59
+ <script>
60
+
61
+ import { OverlayManager } from './overlay-manager.js';
62
+ import VdButton from '../button';
63
+
64
+ export default {
65
+ name: 'vd-dialog',
66
+ components: {
67
+ VdButton
68
+ },
69
+ props: {
70
+ value: Boolean,
71
+ btns: Boolean,
72
+ btnsBlock: Boolean,
73
+ btn: Boolean,
74
+ btnsText: Boolean,
75
+ btnTextBlock: Boolean,
76
+ message: String,
77
+ title: String,
78
+ className: String,
79
+ overlay: {
80
+ type: Boolean,
81
+ default: true
82
+ },
83
+ confirmButtonText: String,
84
+ cancelButtonText: String,
85
+ closeOnOverlay: {
86
+ type: Boolean,
87
+ default: true
88
+ },
89
+ width: [Number, String],
90
+ },
91
+ data() {
92
+ return {
93
+ isOverlayVisible: false,
94
+ overlayZIndex: 2000
95
+ }
96
+ },
97
+ watch: {
98
+ visible: {
99
+ immediate: true,
100
+ handler(val) {
101
+ if (val) {
102
+ this.showOverlayLayer();
103
+ } else {
104
+ this.hideOverlayLayer();
105
+ }
106
+ },
107
+ },
108
+ },
109
+ computed: {
110
+ visible() {
111
+ return this.value
112
+ },
113
+ computedClassName() {
114
+ return this.className ? `vd-dialog--${this.className}` : '';
115
+ },
116
+ },
117
+ methods: {
118
+ showOverlayLayer() {
119
+ if (this.overlay) {
120
+ OverlayManager.increment();
121
+ this.isOverlayVisible = OverlayManager.isOverlayVisible();
122
+ this.overlayZIndex = OverlayManager.getZIndex();
123
+ }
124
+ },
125
+ hideOverlayLayer() {
126
+ if (this.overlay) {
127
+ OverlayManager.decrement();
128
+ this.isOverlayVisible = OverlayManager.isOverlayVisible();
129
+ this.overlayZIndex = OverlayManager.getZIndex(); // 更新 z-index,以便其他遮罩正确显示
130
+ }
131
+ },
132
+ handleOverlayClick() {
133
+ if (this.closeOnOverlay) {
134
+ this.closeDialog();
135
+ }
136
+ },
137
+ closeDialog() {
138
+ this.$emit('input', false);
139
+ },
140
+ cancel() {
141
+ this.closeDialog();
142
+ this.$emit('cancel');
143
+ },
144
+ confirm() {
145
+ this.closeDialog();
146
+ this.$emit('confirm');
147
+ },
148
+ },
149
+ mounted() {
150
+ if (this.visible) {
151
+ this.showOverlayLayer();
152
+ }
153
+ },
154
+ beforeDestroy() {
155
+ if (this.visible) {
156
+ this.hideOverlayLayer();
157
+ }
158
+ }
159
+ }
160
+ </script>
161
+
162
+ <style lang="less">
163
+ @import './style.less';
164
+ </style>
@@ -1,18 +1,18 @@
1
-
2
- let overlayCount = 0;
3
-
4
- export const OverlayManager = {
5
- increment() {
6
- overlayCount += 1;
7
- },
8
- decrement() {
9
- overlayCount -= 1;
10
- if (overlayCount < 0) overlayCount = 0;
11
- },
12
- isOverlayVisible() {
13
- return overlayCount > 0;
14
- },
15
- getZIndex() {
16
- return 2000 + overlayCount; // 每个遮罩层递增的 z-index
17
- }
18
- };
1
+
2
+ let overlayCount = 0;
3
+
4
+ export const OverlayManager = {
5
+ increment() {
6
+ overlayCount += 1;
7
+ },
8
+ decrement() {
9
+ overlayCount -= 1;
10
+ if (overlayCount < 0) overlayCount = 0;
11
+ },
12
+ isOverlayVisible() {
13
+ return overlayCount > 0;
14
+ },
15
+ getZIndex() {
16
+ return 2000 + overlayCount; // 每个遮罩层递增的 z-index
17
+ }
18
+ };