@zkwq/business 0.0.4 → 0.0.6

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 (227) hide show
  1. package/package.json +2 -2
  2. package/src/components/base/ui/alert/Alert.vue +0 -94
  3. package/src/components/base/ui/autocomplete/autocomplete-suggestions.vue +0 -77
  4. package/src/components/base/ui/autocomplete/autocomplete.vue +0 -305
  5. package/src/components/base/ui/backtop/main.vue +0 -112
  6. package/src/components/base/ui/button/Button.vue +0 -84
  7. package/src/components/base/ui/button/ButtonGroup.vue +0 -10
  8. package/src/components/base/ui/carousel/Carousel.vue +0 -304
  9. package/src/components/base/ui/carousel/CarouselItem.vue +0 -137
  10. package/src/components/base/ui/cascader/cascader.vue +0 -650
  11. package/src/components/base/ui/cascader-panel/cascader-menu.vue +0 -138
  12. package/src/components/base/ui/cascader-panel/cascader-node.vue +0 -246
  13. package/src/components/base/ui/cascader-panel/cascader-panel.vue +0 -382
  14. package/src/components/base/ui/cascader-panel/node.js +0 -166
  15. package/src/components/base/ui/cascader-panel/store.js +0 -62
  16. package/src/components/base/ui/checkbox/checkbox-button.vue +0 -199
  17. package/src/components/base/ui/checkbox/checkbox-group.vue +0 -48
  18. package/src/components/base/ui/checkbox/checkbox.vue +0 -222
  19. package/src/components/base/ui/col/col.js +0 -71
  20. package/src/components/base/ui/collapse/collapse-item.vue +0 -180
  21. package/src/components/base/ui/collapse/collapse.vue +0 -73
  22. package/src/components/base/ui/color-picker/color.js +0 -317
  23. package/src/components/base/ui/color-picker/components/alpha-slider.vue +0 -132
  24. package/src/components/base/ui/color-picker/components/hue-slider.vue +0 -123
  25. package/src/components/base/ui/color-picker/components/picker-dropdown.vue +0 -119
  26. package/src/components/base/ui/color-picker/components/predefine.vue +0 -61
  27. package/src/components/base/ui/color-picker/components/sv-panel.vue +0 -100
  28. package/src/components/base/ui/color-picker/draggable.js +0 -36
  29. package/src/components/base/ui/color-picker/index.js +0 -2
  30. package/src/components/base/ui/color-picker/main.vue +0 -188
  31. package/src/components/base/ui/date-picker/basic/date-table.vue +0 -441
  32. package/src/components/base/ui/date-picker/basic/month-table.vue +0 -254
  33. package/src/components/base/ui/date-picker/basic/time-spinner.vue +0 -304
  34. package/src/components/base/ui/date-picker/basic/year-table.vue +0 -101
  35. package/src/components/base/ui/date-picker/panel/date-range.vue +0 -680
  36. package/src/components/base/ui/date-picker/panel/date.vue +0 -597
  37. package/src/components/base/ui/date-picker/panel/month-range.vue +0 -289
  38. package/src/components/base/ui/date-picker/panel/time-range.vue +0 -248
  39. package/src/components/base/ui/date-picker/panel/time-select.vue +0 -178
  40. package/src/components/base/ui/date-picker/panel/time.vue +0 -186
  41. package/src/components/base/ui/date-picker/picker/date-picker.js +0 -43
  42. package/src/components/base/ui/date-picker/picker/time-picker.js +0 -39
  43. package/src/components/base/ui/date-picker/picker/time-select.js +0 -21
  44. package/src/components/base/ui/date-picker/picker.vue +0 -942
  45. package/src/components/base/ui/dialog/Index.vue +0 -212
  46. package/src/components/base/ui/directive/repeat-click.js +0 -24
  47. package/src/components/base/ui/directive/ripple.js +0 -303
  48. package/src/components/base/ui/divider/Divider.vue +0 -37
  49. package/src/components/base/ui/drawer/Drawer.vue +0 -202
  50. package/src/components/base/ui/dropdown/dropdown-item.vue +0 -39
  51. package/src/components/base/ui/dropdown/dropdown-menu.vue +0 -63
  52. package/src/components/base/ui/dropdown/dropdown.vue +0 -308
  53. package/src/components/base/ui/form/Form.vue +0 -167
  54. package/src/components/base/ui/form/FormItem.vue +0 -334
  55. package/src/components/base/ui/form/LabelWrap.vue +0 -69
  56. package/src/components/base/ui/icon/icon.vue +0 -13
  57. package/src/components/base/ui/image/image-viewer.vue +0 -302
  58. package/src/components/base/ui/image/main.vue +0 -248
  59. package/src/components/base/ui/index.js +0 -189
  60. package/src/components/base/ui/input/Input.vue +0 -438
  61. package/src/components/base/ui/input/calcTextareaHeight.js +0 -104
  62. package/src/components/base/ui/input-number/input-number.vue +0 -285
  63. package/src/components/base/ui/locale/format.js +0 -32
  64. package/src/components/base/ui/locale/index.js +0 -48
  65. package/src/components/base/ui/locale/lang/zh-CN.js +0 -120
  66. package/src/components/base/ui/menu/menu-item-group.vue +0 -45
  67. package/src/components/base/ui/menu/menu-item.vue +0 -112
  68. package/src/components/base/ui/menu/menu-mixin.js +0 -44
  69. package/src/components/base/ui/menu/menu.vue +0 -312
  70. package/src/components/base/ui/menu/submenu.vue +0 -408
  71. package/src/components/base/ui/message/index.js +0 -2
  72. package/src/components/base/ui/message/main.js +0 -87
  73. package/src/components/base/ui/message/main.vue +0 -110
  74. package/src/components/base/ui/message-box/main.js +0 -216
  75. package/src/components/base/ui/message-box/main.vue +0 -323
  76. package/src/components/base/ui/mixin/emitter.js +0 -31
  77. package/src/components/base/ui/mixin/focus.js +0 -9
  78. package/src/components/base/ui/mixin/locale.js +0 -9
  79. package/src/components/base/ui/mixin/migrating.js +0 -33
  80. package/src/components/base/ui/pagination/pager.vue +0 -163
  81. package/src/components/base/ui/pagination/pagination.jsx +0 -391
  82. package/src/components/base/ui/popover/directive.js +0 -20
  83. package/src/components/base/ui/popover/index.js +0 -14
  84. package/src/components/base/ui/popover/main.vue +0 -236
  85. package/src/components/base/ui/progress/Progress.vue +0 -227
  86. package/src/components/base/ui/radio/radio-button.vue +0 -114
  87. package/src/components/base/ui/radio/radio-group.vue +0 -111
  88. package/src/components/base/ui/radio/radio.vue +0 -134
  89. package/src/components/base/ui/row/row.js +0 -47
  90. package/src/components/base/ui/scrollbar/bar.jsx +0 -91
  91. package/src/components/base/ui/scrollbar/index.jsx +0 -203
  92. package/src/components/base/ui/scrollbar/util.js +0 -32
  93. package/src/components/base/ui/select/Option.vue +0 -168
  94. package/src/components/base/ui/select/OptionGroup.vue +0 -60
  95. package/src/components/base/ui/select/Select.vue +0 -920
  96. package/src/components/base/ui/select/SelectDropdown.vue +0 -74
  97. package/src/components/base/ui/select/navigation-mixin.js +0 -54
  98. package/src/components/base/ui/skeleton/index.js +0 -8
  99. package/src/components/base/ui/skeleton/src/img-placeholder.vue +0 -16
  100. package/src/components/base/ui/skeleton/src/index.vue +0 -80
  101. package/src/components/base/ui/skeleton/src/item.vue +0 -22
  102. package/src/components/base/ui/skeleton-item/index.js +0 -8
  103. package/src/components/base/ui/slider/button.vue +0 -238
  104. package/src/components/base/ui/slider/main.vue +0 -427
  105. package/src/components/base/ui/slider/marker.js +0 -18
  106. package/src/components/base/ui/style/alert.scss +0 -147
  107. package/src/components/base/ui/style/animations.scss +0 -65
  108. package/src/components/base/ui/style/autocomplete.scss +0 -81
  109. package/src/components/base/ui/style/backtop.scss +0 -20
  110. package/src/components/base/ui/style/button-group.scss +0 -0
  111. package/src/components/base/ui/style/button.scss +0 -380
  112. package/src/components/base/ui/style/carousel-item.scss +0 -50
  113. package/src/components/base/ui/style/carousel.scss +0 -161
  114. package/src/components/base/ui/style/cascader-panel.scss +0 -120
  115. package/src/components/base/ui/style/cascader.scss +0 -185
  116. package/src/components/base/ui/style/checkbox-button.scss +0 -0
  117. package/src/components/base/ui/style/checkbox-group.scss +0 -0
  118. package/src/components/base/ui/style/checkbox.scss +0 -360
  119. package/src/components/base/ui/style/col.scss +0 -156
  120. package/src/components/base/ui/style/collapse-item.scss +0 -0
  121. package/src/components/base/ui/style/collapse.scss +0 -114
  122. package/src/components/base/ui/style/color-picker.scss +0 -387
  123. package/src/components/base/ui/style/config.scss +0 -4
  124. package/src/components/base/ui/style/date-picker/date-picker.scss +0 -97
  125. package/src/components/base/ui/style/date-picker/date-range-picker.scss +0 -101
  126. package/src/components/base/ui/style/date-picker/date-table.scss +0 -151
  127. package/src/components/base/ui/style/date-picker/month-table.scss +0 -82
  128. package/src/components/base/ui/style/date-picker/picker-panel.scss +0 -117
  129. package/src/components/base/ui/style/date-picker/picker.scss +0 -197
  130. package/src/components/base/ui/style/date-picker/time-picker.scss +0 -85
  131. package/src/components/base/ui/style/date-picker/time-range-picker.scss +0 -31
  132. package/src/components/base/ui/style/date-picker/time-spinner.scss +0 -110
  133. package/src/components/base/ui/style/date-picker/year-table.scss +0 -51
  134. package/src/components/base/ui/style/date-picker.scss +0 -12
  135. package/src/components/base/ui/style/dialog.scss +0 -123
  136. package/src/components/base/ui/style/divider.scss +0 -47
  137. package/src/components/base/ui/style/drawer.scss +0 -218
  138. package/src/components/base/ui/style/dropdown-item.scss +0 -0
  139. package/src/components/base/ui/style/dropdown-menu.scss +0 -0
  140. package/src/components/base/ui/style/dropdown.scss +0 -185
  141. package/src/components/base/ui/style/form-item.scss +0 -0
  142. package/src/components/base/ui/style/form.scss +0 -203
  143. package/src/components/base/ui/style/function.scss +0 -43
  144. package/src/components/base/ui/style/icon.scss +0 -1167
  145. package/src/components/base/ui/style/image.scss +0 -184
  146. package/src/components/base/ui/style/index.scss +0 -57
  147. package/src/components/base/ui/style/input-number.scss +0 -187
  148. package/src/components/base/ui/style/input.scss +0 -477
  149. package/src/components/base/ui/style/menu-item-group.scss +0 -0
  150. package/src/components/base/ui/style/menu-item.scss +0 -0
  151. package/src/components/base/ui/style/menu.scss +0 -294
  152. package/src/components/base/ui/style/message-box.scss +0 -231
  153. package/src/components/base/ui/style/message.scss +0 -120
  154. package/src/components/base/ui/style/mixins.scss +0 -196
  155. package/src/components/base/ui/style/option-group.scss +0 -42
  156. package/src/components/base/ui/style/option.scss +0 -36
  157. package/src/components/base/ui/style/pagination.scss +0 -295
  158. package/src/components/base/ui/style/popover.scss +0 -40
  159. package/src/components/base/ui/style/popper.scss +0 -102
  160. package/src/components/base/ui/style/popup.scss +0 -42
  161. package/src/components/base/ui/style/progress.scss +0 -141
  162. package/src/components/base/ui/style/radio-button.scss +0 -113
  163. package/src/components/base/ui/style/radio-group.scss +0 -9
  164. package/src/components/base/ui/style/radio.scss +0 -203
  165. package/src/components/base/ui/style/ripple.scss +0 -35
  166. package/src/components/base/ui/style/row.scss +0 -39
  167. package/src/components/base/ui/style/scrollbar.scss +0 -75
  168. package/src/components/base/ui/style/select-dropdown.scss +0 -59
  169. package/src/components/base/ui/style/select.scss +0 -154
  170. package/src/components/base/ui/style/skeleton-item.scss +0 -84
  171. package/src/components/base/ui/style/skeleton.scss +0 -40
  172. package/src/components/base/ui/style/slider.scss +0 -250
  173. package/src/components/base/ui/style/switch.scss +0 -116
  174. package/src/components/base/ui/style/tabs.scss +0 -602
  175. package/src/components/base/ui/style/tag.scss +0 -174
  176. package/src/components/base/ui/style/tooltip.scss +0 -146
  177. package/src/components/base/ui/style/transition.scss +0 -138
  178. package/src/components/base/ui/style/upload.scss +0 -603
  179. package/src/components/base/ui/style/utils.scss +0 -39
  180. package/src/components/base/ui/style/var.scss +0 -1011
  181. package/src/components/base/ui/switch/index.vue +0 -174
  182. package/src/components/base/ui/tabs/tab-bar.vue +0 -57
  183. package/src/components/base/ui/tabs/tab-nav.vue +0 -294
  184. package/src/components/base/ui/tabs/tab-pane.vue +0 -56
  185. package/src/components/base/ui/tabs/tabs.vue +0 -191
  186. package/src/components/base/ui/tag/Tag.vue +0 -60
  187. package/src/components/base/ui/tooltip/tooltip.jsx +0 -234
  188. package/src/components/base/ui/upload/Index.vue +0 -340
  189. package/src/components/base/ui/upload/Upload.vue +0 -216
  190. package/src/components/base/ui/upload/UploadDragger.vue +0 -70
  191. package/src/components/base/ui/upload/UploadList.vue +0 -100
  192. package/src/components/base/ui/upload/ajax.js +0 -85
  193. package/src/components/base/ui/util/aria-dialog.js +0 -90
  194. package/src/components/base/ui/util/aria-utils.js +0 -122
  195. package/src/components/base/ui/util/clickoutside.js +0 -76
  196. package/src/components/base/ui/util/date-util.js +0 -292
  197. package/src/components/base/ui/util/date.js +0 -355
  198. package/src/components/base/ui/util/debounce.js +0 -21
  199. package/src/components/base/ui/util/deepmerge.js +0 -100
  200. package/src/components/base/ui/util/dom.js +0 -215
  201. package/src/components/base/ui/util/index.js +0 -262
  202. package/src/components/base/ui/util/menu/aria-menubar.js +0 -14
  203. package/src/components/base/ui/util/menu/aria-menuitem.js +0 -49
  204. package/src/components/base/ui/util/menu/aria-submenu.js +0 -59
  205. package/src/components/base/ui/util/merge.js +0 -14
  206. package/src/components/base/ui/util/popper.js +0 -1235
  207. package/src/components/base/ui/util/popup/index.js +0 -218
  208. package/src/components/base/ui/util/popup/popup-manager.js +0 -194
  209. package/src/components/base/ui/util/resize-events.js +0 -32
  210. package/src/components/base/ui/util/scroll-into-view.js +0 -27
  211. package/src/components/base/ui/util/scrollbar-width.js +0 -29
  212. package/src/components/base/ui/util/shared.js +0 -7
  213. package/src/components/base/ui/util/throttle.js +0 -91
  214. package/src/components/base/ui/util/types.js +0 -24
  215. package/src/components/base/ui/util/vdom.js +0 -5
  216. package/src/components/base/ui/util/vue-popper.js +0 -188
  217. package/src/components/normal/AggsItemH.vue +0 -145
  218. package/src/index.js +0 -10
  219. package/src/static/base-icons.ttf +0 -0
  220. package/src/static/base-icons.woff +0 -0
  221. package/src/static/label_bg.png +0 -0
  222. package/src/static/term-label-bg.png +0 -0
  223. package/src/style/app-article.scss +0 -698
  224. package/src/style/app-comment.scss +0 -259
  225. package/src/style/app-recommend.scss +0 -48
  226. package/src/style/app-richtext.scss +0 -176
  227. package/src/style/index.scss +0 -523
@@ -1,212 +0,0 @@
1
- <template>
2
- <transition
3
- name="dialog-fade"
4
- @after-enter="afterEnter"
5
- @after-leave="afterLeave">
6
- <div
7
- v-show="visible"
8
- class="base-dialog__wrapper"
9
- @click.self="handleWrapperClick">
10
- <div
11
- role="dialog"
12
- :key="key"
13
- aria-modal="true"
14
- :aria-label="title || 'dialog'"
15
- :class="['base-dialog', { 'is-fullscreen': fullscreen, 'base-dialog--center': center }, customClass]"
16
- ref="dialog"
17
- :style="style">
18
- <div class="base-dialog__header">
19
- <slot name="title">
20
- <span class="base-dialog__title">{{ title }}</span>
21
- </slot>
22
- <button
23
- type="button"
24
- class="base-dialog__headerbtn"
25
- aria-label="Close"
26
- v-if="showClose"
27
- @click="handleClose">
28
- <i class="base-dialog__close base-icon base-icon-close"></i>
29
- </button>
30
- </div>
31
- <div class="base-dialog__body" v-if="rendered"><slot></slot></div>
32
- <div class="base-dialog__footer" v-if="$slots.footer">
33
- <slot name="footer"></slot>
34
- </div>
35
- </div>
36
- </div>
37
- </transition>
38
- </template>
39
-
40
- <script>
41
- import Popup from '../util/popup'
42
- import Migrating from '../mixin/migrating'
43
- import emitter from '../mixin/emitter'
44
-
45
- export default {
46
- name: 'BaseDialog',
47
-
48
- mixins: [Popup, emitter, Migrating],
49
-
50
- props: {
51
- title: {
52
- type: String,
53
- default: ''
54
- },
55
-
56
- modal: {
57
- type: Boolean,
58
- default: true
59
- },
60
-
61
- modalAppendToBody: {
62
- type: Boolean,
63
- default: true
64
- },
65
-
66
- appendToBody: {
67
- type: Boolean,
68
- default: false
69
- },
70
-
71
- lockScroll: {
72
- type: Boolean,
73
- default: true
74
- },
75
-
76
- closeOnClickModal: {
77
- type: Boolean,
78
- default: true
79
- },
80
-
81
- closeOnPressEscape: {
82
- type: Boolean,
83
- default: true
84
- },
85
-
86
- showClose: {
87
- type: Boolean,
88
- default: true
89
- },
90
-
91
- width: String,
92
-
93
- fullscreen: Boolean,
94
-
95
- customClass: {
96
- type: String,
97
- default: ''
98
- },
99
-
100
- top: {
101
- type: String,
102
- default: '15vh'
103
- },
104
- beforeClose: Function,
105
- center: {
106
- type: Boolean,
107
- default: false
108
- },
109
-
110
- destroyOnClose: Boolean
111
- },
112
-
113
- data() {
114
- return {
115
- closed: false,
116
- key: 0
117
- };
118
- },
119
-
120
- watch: {
121
- visible(val) {
122
- if (val) {
123
- this.closed = false;
124
- this.$emit('open');
125
- this.$el.addEventListener('scroll', this.updatePopper);
126
- this.$nextTick(() => {
127
- this.$refs.dialog.scrollTop = 0;
128
- });
129
- if (this.appendToBody) {
130
- document.body.appendChild(this.$el);
131
- }
132
- } else {
133
- this.$el.removeEventListener('scroll', this.updatePopper);
134
- if (!this.closed) this.$emit('close');
135
- if (this.destroyOnClose) {
136
- this.$nextTick(() => {
137
- this.key++;
138
- });
139
- }
140
- }
141
- }
142
- },
143
-
144
- computed: {
145
- style() {
146
- let style = {};
147
- if (!this.fullscreen) {
148
- style.marginTop = this.top;
149
- if (this.width) {
150
- style.width = this.width;
151
- }
152
- }
153
- return style;
154
- }
155
- },
156
-
157
- methods: {
158
- getMigratingConfig() {
159
- return {
160
- props: {
161
- 'size': 'size is removed.'
162
- }
163
- };
164
- },
165
- handleWrapperClick() {
166
- if (!this.closeOnClickModal) return;
167
- this.handleClose();
168
- },
169
- handleClose() {
170
- if (typeof this.beforeClose === 'function') {
171
- this.beforeClose(this.hide);
172
- } else {
173
- this.hide();
174
- }
175
- },
176
- hide(cancel) {
177
- if (cancel !== false) {
178
- this.$emit('update:visible', false);
179
- this.$emit('close');
180
- this.closed = true;
181
- }
182
- },
183
- updatePopper() {
184
- this.broadcast('BaseSelectDropdown', 'updatePopper');
185
- this.broadcast('BaseDropdownMenu', 'updatePopper');
186
- },
187
- afterEnter() {
188
- this.$emit('opened');
189
- },
190
- afterLeave() {
191
- this.$emit('closed');
192
- }
193
- },
194
-
195
- mounted() {
196
- if (this.visible) {
197
- this.rendered = true;
198
- this.open();
199
- if (this.appendToBody) {
200
- document.body.appendChild(this.$el);
201
- }
202
- }
203
- },
204
-
205
- destroyed() {
206
- // if appendToBody is true, remove DOM node after destroy
207
- if (this.appendToBody && this.$el && this.$el.parentNode) {
208
- this.$el.parentNode.removeChild(this.$el);
209
- }
210
- }
211
- };
212
- </script>
@@ -1,24 +0,0 @@
1
- import { once, on } from '../util/dom';
2
-
3
- export default {
4
- bind(el, binding, vnode) {
5
- let interval = null;
6
- let startTime;
7
- const handler = () => vnode.context[binding.expression].apply();
8
- const clear = () => {
9
- if (Date.now() - startTime < 100) {
10
- handler();
11
- }
12
- clearInterval(interval);
13
- interval = null;
14
- };
15
-
16
- on(el, 'mousedown', (e) => {
17
- if (e.button !== 0) return;
18
- startTime = Date.now();
19
- once(document, 'mouseup', clear);
20
- clearInterval(interval);
21
- interval = setInterval(handler, 100);
22
- });
23
- }
24
- };
@@ -1,303 +0,0 @@
1
- const DELAY_RIPPLE = 80
2
-
3
- function transform (el, value) {
4
- el.style.transform = value
5
- el.style.webkitTransform = value
6
- }
7
-
8
- function opacity (el, value) {
9
- el.style.opacity = value.toString()
10
- }
11
-
12
- function isTouchEvent (e) {
13
- return e.constructor.name === 'TouchEvent'
14
- }
15
-
16
- function isKeyboardEvent (e) {
17
- return e.constructor.name === 'KeyboardEvent'
18
- }
19
-
20
- const calculate = (e, el, value) => {
21
- let localX = 0
22
- let localY = 0
23
-
24
- if (!isKeyboardEvent(e)) {
25
- const offset = el.getBoundingClientRect()
26
- const target = isTouchEvent(e) ? e.touches[e.touches.length - 1] : e
27
-
28
- localX = target.clientX - offset.left
29
- localY = target.clientY - offset.top
30
- }
31
-
32
- let radius = 0
33
- let scale = 0.3
34
- if (el._ripple && el._ripple.circle) {
35
- scale = 0.15
36
- radius = el.offsetWidth / 2
37
- radius = value.center ? radius : radius + Math.sqrt((localX - radius) ** 2 + (localY - radius) ** 2) / 4
38
- } else {
39
- radius = Math.sqrt(el.offsetWidth ** 2 + el.offsetHeight ** 2) / 2
40
- }
41
- const centerX = `${(el.offsetWidth - (radius * 2)) / 2}px`
42
- const centerY = `${(el.offsetHeight - (radius * 2)) / 2}px`
43
-
44
- const x = value.center ? centerX : `${localX - radius}px`
45
- const y = value.center ? centerY : `${localY - radius}px`
46
-
47
- return { radius, scale, x, y, centerX, centerY }
48
- }
49
-
50
-
51
- const ripples = {
52
- /**
53
- * @param {Event} e
54
- * @param {Element} el
55
- * @param {{ class?: string, center?: boolean }} [value={}]
56
- */
57
- show (e, el, value = {}) {
58
- if (!el._ripple || !el._ripple.enabled) {
59
- return
60
- }
61
-
62
- const container = document.createElement('span')
63
- const animation = document.createElement('span')
64
-
65
- container.appendChild(animation)
66
- container.className = 'v-ripple__container'
67
-
68
- if (value.class) {
69
- container.className += ` ${value.class}`
70
- }
71
-
72
- const { radius, scale, x, y, centerX, centerY } = calculate(e, el, value)
73
-
74
- const size = `${radius * 2}px`
75
- animation.className = 'v-ripple__animation'
76
- animation.style.width = size
77
- animation.style.height = size
78
-
79
- el.appendChild(container)
80
-
81
- const computed = window.getComputedStyle(el)
82
- if (computed && computed.position === 'static') {
83
- el.style.position = 'relative'
84
- el.dataset.previousPosition = 'static'
85
- }
86
-
87
- animation.classList.add('v-ripple__animation--enter')
88
- animation.classList.add('v-ripple__animation--visible')
89
- transform(animation, `translate(${x}, ${y}) scale3d(${scale},${scale},${scale})`)
90
- opacity(animation, 0)
91
- animation.dataset.activated = String(performance.now())
92
-
93
- setTimeout(() => {
94
- animation.classList.remove('v-ripple__animation--enter')
95
- animation.classList.add('v-ripple__animation--in')
96
- transform(animation, `translate(${centerX}, ${centerY}) scale3d(1,1,1)`)
97
- opacity(animation, 0.25)
98
- }, 0)
99
- },
100
-
101
-
102
- hide: el => {
103
- if (!el || !el._ripple || !el._ripple.enabled) return
104
-
105
- const ripples = el.getElementsByClassName('v-ripple__animation')
106
-
107
- if (ripples.length === 0) return
108
- const animation = ripples[ripples.length - 1]
109
-
110
- if (animation.dataset.isHiding) return
111
- else animation.dataset.isHiding = 'true'
112
-
113
- const diff = performance.now() - Number(animation.dataset.activated)
114
- const delay = Math.max(250 - diff, 0)
115
-
116
- setTimeout(() => {
117
- animation.classList.remove('v-ripple__animation--in')
118
- animation.classList.add('v-ripple__animation--out')
119
- opacity(animation, 0)
120
-
121
- setTimeout(() => {
122
- const ripples = el.getElementsByClassName('v-ripple__animation')
123
- if (ripples.length === 1 && el.dataset.previousPosition) {
124
- el.style.position = el.dataset.previousPosition
125
- delete el.dataset.previousPosition
126
- }
127
-
128
- animation.parentNode && el.removeChild(animation.parentNode)
129
- }, 300)
130
- }, delay)
131
- }
132
- }
133
-
134
- function isRippleEnabled (value) {
135
- return typeof value === 'undefined' || !!value
136
- }
137
-
138
- function rippleShow (e) {
139
- const value = {}
140
- const element = e.currentTarget
141
- if (!element || !element._ripple || element._ripple.touched) return
142
- if (isTouchEvent(e)) {
143
- element._ripple.touched = true
144
- element._ripple.isTouch = true
145
- } else {
146
- // It's possible for touch events to fire
147
- // as mouse events on Android/iOS, this
148
- // will skip the event call if it has
149
- // already been registered as touch
150
- if (element._ripple.isTouch) return
151
- }
152
- value.center = element._ripple.centered || isKeyboardEvent(e)
153
- if (element._ripple.class) {
154
- value.class = element._ripple.class
155
- }
156
-
157
- if (isTouchEvent(e)) {
158
- // already queued that shows or hides the ripple
159
- if (element._ripple.showTimerCommit) return
160
-
161
- element._ripple.showTimerCommit = () => {
162
- ripples.show(e, element, value)
163
- }
164
- element._ripple.showTimer = window.setTimeout(() => {
165
- if (element && element._ripple && element._ripple.showTimerCommit) {
166
- element._ripple.showTimerCommit()
167
- element._ripple.showTimerCommit = null
168
- }
169
- }, DELAY_RIPPLE)
170
- } else {
171
- ripples.show(e, element, value)
172
- }
173
- }
174
-
175
- function rippleHide (e) {
176
- const element = e.currentTarget
177
- if (!element || !element._ripple) return
178
-
179
- window.clearTimeout(element._ripple.showTimer)
180
-
181
- // The touch interaction occurs before the show timer is triggered.
182
- // We still want to show ripple effect.
183
- if (e.type === 'touchend' && element._ripple.showTimerCommit) {
184
- element._ripple.showTimerCommit()
185
- element._ripple.showTimerCommit = null
186
-
187
- // re-queue ripple hiding
188
- element._ripple.showTimer = setTimeout(() => {
189
- rippleHide(e)
190
- })
191
- return
192
- }
193
-
194
- window.setTimeout(() => {
195
- if (element._ripple) {
196
- element._ripple.touched = false
197
- }
198
- })
199
- ripples.hide(element)
200
- }
201
-
202
- function rippleCancelShow (e) {
203
- const element = e.currentTarget
204
-
205
- if (!element || !element._ripple) return
206
-
207
- if (element._ripple.showTimerCommit) {
208
- element._ripple.showTimerCommit = null
209
- }
210
-
211
- window.clearTimeout(element._ripple.showTimer)
212
- }
213
-
214
- let keyboardRipple = false
215
-
216
- function keyboardRippleShow (e) {
217
- if (!keyboardRipple && (e.keyCode === keyCodes.enter || e.keyCode === keyCodes.space)) {
218
- keyboardRipple = true
219
- rippleShow(e)
220
- }
221
- }
222
-
223
- function keyboardRippleHide (e) {
224
- keyboardRipple = false
225
- rippleHide(e)
226
- }
227
-
228
- function updateRipple (el, binding, wasEnabled) {
229
- const enabled = isRippleEnabled(binding.value)
230
- if (!enabled) {
231
- ripples.hide(el)
232
- }
233
- el._ripple = el._ripple || {}
234
- el._ripple.enabled = enabled
235
- const value = binding.value || {}
236
- if (value.center) {
237
- el._ripple.centered = true
238
- }
239
- if (value.class) {
240
- el._ripple.class = binding.value.class
241
- }
242
- if (value.circle) {
243
- el._ripple.circle = value.circle
244
- }
245
- if (enabled && !wasEnabled) {
246
- el.addEventListener('touchstart', rippleShow, { passive: true })
247
- el.addEventListener('touchend', rippleHide, { passive: true })
248
- el.addEventListener('touchmove', rippleCancelShow, { passive: true })
249
- el.addEventListener('touchcancel', rippleHide)
250
-
251
- el.addEventListener('mousedown', rippleShow)
252
- el.addEventListener('mouseup', rippleHide)
253
- el.addEventListener('mouseleave', rippleHide)
254
-
255
- el.addEventListener('keydown', keyboardRippleShow)
256
- el.addEventListener('keyup', keyboardRippleHide)
257
-
258
- // Anchor tags can be dragged, causes other hides to fail - #1537
259
- el.addEventListener('dragstart', rippleHide, { passive: true })
260
- } else if (!enabled && wasEnabled) {
261
- removeListeners(el)
262
- }
263
- }
264
-
265
- function removeListeners (el) {
266
- el.removeEventListener('mousedown', rippleShow)
267
- el.removeEventListener('touchstart', rippleShow)
268
- el.removeEventListener('touchend', rippleHide)
269
- el.removeEventListener('touchmove', rippleCancelShow)
270
- el.removeEventListener('touchcancel', rippleHide)
271
- el.removeEventListener('mouseup', rippleHide)
272
- el.removeEventListener('mouseleave', rippleHide)
273
- el.removeEventListener('keydown', keyboardRippleShow)
274
- el.removeEventListener('keyup', keyboardRippleHide)
275
- el.removeEventListener('dragstart', rippleHide)
276
- }
277
-
278
- function directive (el, binding) {
279
- updateRipple(el, binding, false)
280
- }
281
-
282
- function unbind (el) {
283
- delete el._ripple
284
- removeListeners(el)
285
- }
286
-
287
- function update (el, binding) {
288
- if (binding.value === binding.oldValue) {
289
- return
290
- }
291
-
292
- const wasEnabled = isRippleEnabled(binding.oldValue)
293
- updateRipple(el, binding, wasEnabled)
294
- }
295
-
296
- export const Ripple = {
297
- name: 'ripple',
298
- bind: directive,
299
- unbind: unbind,
300
- update: update
301
- }
302
-
303
- export default Ripple
@@ -1,37 +0,0 @@
1
- <template functional>
2
- <div
3
- v-bind="data.attrs"
4
- v-on="listeners"
5
- :class="[data.staticClass, 'base-divider', `base-divider--${props.direction}`]"
6
- >
7
- <div
8
- v-if="slots().default && props.direction !== 'vertical'"
9
- :class="['base-divider__text', `is-${props.contentPosition}`]"
10
- >
11
- <slot />
12
- </div>
13
- </div>
14
- </template>
15
-
16
- <script>
17
- export default {
18
- name: 'BaseDivider',
19
- props: {
20
- direction: {
21
- type: String,
22
- default: 'horizontal',
23
- validator(val) {
24
- return ['horizontal', 'vertical'].indexOf(val) !== -1
25
- }
26
- },
27
- contentPosition: {
28
- type: String,
29
- default: 'center',
30
- validator(val) {
31
- return ['left', 'center', 'right'].indexOf(val) !== -1
32
- }
33
- }
34
- }
35
- }
36
-
37
- </script>