@zkwq/business 0.0.1

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 (231) hide show
  1. package/dist/index.css +1 -0
  2. package/dist/index.js +21861 -0
  3. package/dist/index.umd.cjs +46 -0
  4. package/package.json +27 -0
  5. package/src/components/base/ui/alert/Alert.vue +94 -0
  6. package/src/components/base/ui/autocomplete/autocomplete-suggestions.vue +77 -0
  7. package/src/components/base/ui/autocomplete/autocomplete.vue +305 -0
  8. package/src/components/base/ui/backtop/main.vue +112 -0
  9. package/src/components/base/ui/button/Button.vue +84 -0
  10. package/src/components/base/ui/button/ButtonGroup.vue +10 -0
  11. package/src/components/base/ui/carousel/Carousel.vue +304 -0
  12. package/src/components/base/ui/carousel/CarouselItem.vue +137 -0
  13. package/src/components/base/ui/cascader/cascader.vue +650 -0
  14. package/src/components/base/ui/cascader-panel/cascader-menu.vue +138 -0
  15. package/src/components/base/ui/cascader-panel/cascader-node.vue +246 -0
  16. package/src/components/base/ui/cascader-panel/cascader-panel.vue +382 -0
  17. package/src/components/base/ui/cascader-panel/node.js +166 -0
  18. package/src/components/base/ui/cascader-panel/store.js +62 -0
  19. package/src/components/base/ui/checkbox/checkbox-button.vue +199 -0
  20. package/src/components/base/ui/checkbox/checkbox-group.vue +48 -0
  21. package/src/components/base/ui/checkbox/checkbox.vue +222 -0
  22. package/src/components/base/ui/col/col.js +71 -0
  23. package/src/components/base/ui/collapse/collapse-item.vue +180 -0
  24. package/src/components/base/ui/collapse/collapse.vue +73 -0
  25. package/src/components/base/ui/color-picker/color.js +317 -0
  26. package/src/components/base/ui/color-picker/components/alpha-slider.vue +132 -0
  27. package/src/components/base/ui/color-picker/components/hue-slider.vue +123 -0
  28. package/src/components/base/ui/color-picker/components/picker-dropdown.vue +119 -0
  29. package/src/components/base/ui/color-picker/components/predefine.vue +61 -0
  30. package/src/components/base/ui/color-picker/components/sv-panel.vue +100 -0
  31. package/src/components/base/ui/color-picker/draggable.js +36 -0
  32. package/src/components/base/ui/color-picker/index.js +2 -0
  33. package/src/components/base/ui/color-picker/main.vue +188 -0
  34. package/src/components/base/ui/date-picker/basic/date-table.vue +441 -0
  35. package/src/components/base/ui/date-picker/basic/month-table.vue +254 -0
  36. package/src/components/base/ui/date-picker/basic/time-spinner.vue +304 -0
  37. package/src/components/base/ui/date-picker/basic/year-table.vue +101 -0
  38. package/src/components/base/ui/date-picker/panel/date-range.vue +680 -0
  39. package/src/components/base/ui/date-picker/panel/date.vue +597 -0
  40. package/src/components/base/ui/date-picker/panel/month-range.vue +289 -0
  41. package/src/components/base/ui/date-picker/panel/time-range.vue +248 -0
  42. package/src/components/base/ui/date-picker/panel/time-select.vue +178 -0
  43. package/src/components/base/ui/date-picker/panel/time.vue +186 -0
  44. package/src/components/base/ui/date-picker/picker/date-picker.js +43 -0
  45. package/src/components/base/ui/date-picker/picker/time-picker.js +39 -0
  46. package/src/components/base/ui/date-picker/picker/time-select.js +21 -0
  47. package/src/components/base/ui/date-picker/picker.vue +942 -0
  48. package/src/components/base/ui/dialog/Index.vue +212 -0
  49. package/src/components/base/ui/directive/repeat-click.js +24 -0
  50. package/src/components/base/ui/directive/ripple.js +303 -0
  51. package/src/components/base/ui/divider/Divider.vue +37 -0
  52. package/src/components/base/ui/drawer/Drawer.vue +202 -0
  53. package/src/components/base/ui/dropdown/dropdown-item.vue +39 -0
  54. package/src/components/base/ui/dropdown/dropdown-menu.vue +63 -0
  55. package/src/components/base/ui/dropdown/dropdown.vue +308 -0
  56. package/src/components/base/ui/form/Form.vue +167 -0
  57. package/src/components/base/ui/form/FormItem.vue +334 -0
  58. package/src/components/base/ui/form/LabelWrap.vue +69 -0
  59. package/src/components/base/ui/icon/icon.vue +13 -0
  60. package/src/components/base/ui/image/image-viewer.vue +302 -0
  61. package/src/components/base/ui/image/main.vue +248 -0
  62. package/src/components/base/ui/index.js +189 -0
  63. package/src/components/base/ui/input/Input.vue +438 -0
  64. package/src/components/base/ui/input/calcTextareaHeight.js +104 -0
  65. package/src/components/base/ui/input-number/input-number.vue +285 -0
  66. package/src/components/base/ui/locale/format.js +32 -0
  67. package/src/components/base/ui/locale/index.js +48 -0
  68. package/src/components/base/ui/locale/lang/zh-CN.js +120 -0
  69. package/src/components/base/ui/menu/menu-item-group.vue +45 -0
  70. package/src/components/base/ui/menu/menu-item.vue +112 -0
  71. package/src/components/base/ui/menu/menu-mixin.js +44 -0
  72. package/src/components/base/ui/menu/menu.vue +312 -0
  73. package/src/components/base/ui/menu/submenu.vue +408 -0
  74. package/src/components/base/ui/message/index.js +2 -0
  75. package/src/components/base/ui/message/main.js +87 -0
  76. package/src/components/base/ui/message/main.vue +110 -0
  77. package/src/components/base/ui/message-box/main.js +216 -0
  78. package/src/components/base/ui/message-box/main.vue +323 -0
  79. package/src/components/base/ui/mixin/emitter.js +31 -0
  80. package/src/components/base/ui/mixin/focus.js +9 -0
  81. package/src/components/base/ui/mixin/locale.js +9 -0
  82. package/src/components/base/ui/mixin/migrating.js +33 -0
  83. package/src/components/base/ui/pagination/pager.vue +163 -0
  84. package/src/components/base/ui/pagination/pagination.jsx +391 -0
  85. package/src/components/base/ui/popover/directive.js +20 -0
  86. package/src/components/base/ui/popover/index.js +14 -0
  87. package/src/components/base/ui/popover/main.vue +236 -0
  88. package/src/components/base/ui/progress/Progress.vue +227 -0
  89. package/src/components/base/ui/radio/radio-button.vue +114 -0
  90. package/src/components/base/ui/radio/radio-group.vue +111 -0
  91. package/src/components/base/ui/radio/radio.vue +134 -0
  92. package/src/components/base/ui/row/row.js +47 -0
  93. package/src/components/base/ui/scrollbar/bar.jsx +91 -0
  94. package/src/components/base/ui/scrollbar/index.jsx +203 -0
  95. package/src/components/base/ui/scrollbar/util.js +32 -0
  96. package/src/components/base/ui/select/Option.vue +168 -0
  97. package/src/components/base/ui/select/OptionGroup.vue +60 -0
  98. package/src/components/base/ui/select/Select.vue +920 -0
  99. package/src/components/base/ui/select/SelectDropdown.vue +74 -0
  100. package/src/components/base/ui/select/navigation-mixin.js +54 -0
  101. package/src/components/base/ui/skeleton/index.js +8 -0
  102. package/src/components/base/ui/skeleton/src/img-placeholder.vue +16 -0
  103. package/src/components/base/ui/skeleton/src/index.vue +80 -0
  104. package/src/components/base/ui/skeleton/src/item.vue +22 -0
  105. package/src/components/base/ui/skeleton-item/index.js +8 -0
  106. package/src/components/base/ui/slider/button.vue +238 -0
  107. package/src/components/base/ui/slider/main.vue +427 -0
  108. package/src/components/base/ui/slider/marker.js +18 -0
  109. package/src/components/base/ui/style/alert.scss +147 -0
  110. package/src/components/base/ui/style/animations.scss +65 -0
  111. package/src/components/base/ui/style/autocomplete.scss +81 -0
  112. package/src/components/base/ui/style/backtop.scss +20 -0
  113. package/src/components/base/ui/style/button-group.scss +0 -0
  114. package/src/components/base/ui/style/button.scss +380 -0
  115. package/src/components/base/ui/style/carousel-item.scss +50 -0
  116. package/src/components/base/ui/style/carousel.scss +161 -0
  117. package/src/components/base/ui/style/cascader-panel.scss +120 -0
  118. package/src/components/base/ui/style/cascader.scss +185 -0
  119. package/src/components/base/ui/style/checkbox-button.scss +0 -0
  120. package/src/components/base/ui/style/checkbox-group.scss +0 -0
  121. package/src/components/base/ui/style/checkbox.scss +360 -0
  122. package/src/components/base/ui/style/col.scss +156 -0
  123. package/src/components/base/ui/style/collapse-item.scss +0 -0
  124. package/src/components/base/ui/style/collapse.scss +114 -0
  125. package/src/components/base/ui/style/color-picker.scss +387 -0
  126. package/src/components/base/ui/style/config.scss +4 -0
  127. package/src/components/base/ui/style/date-picker/date-picker.scss +97 -0
  128. package/src/components/base/ui/style/date-picker/date-range-picker.scss +101 -0
  129. package/src/components/base/ui/style/date-picker/date-table.scss +151 -0
  130. package/src/components/base/ui/style/date-picker/month-table.scss +82 -0
  131. package/src/components/base/ui/style/date-picker/picker-panel.scss +117 -0
  132. package/src/components/base/ui/style/date-picker/picker.scss +197 -0
  133. package/src/components/base/ui/style/date-picker/time-picker.scss +85 -0
  134. package/src/components/base/ui/style/date-picker/time-range-picker.scss +31 -0
  135. package/src/components/base/ui/style/date-picker/time-spinner.scss +110 -0
  136. package/src/components/base/ui/style/date-picker/year-table.scss +51 -0
  137. package/src/components/base/ui/style/date-picker.scss +12 -0
  138. package/src/components/base/ui/style/dialog.scss +123 -0
  139. package/src/components/base/ui/style/divider.scss +47 -0
  140. package/src/components/base/ui/style/drawer.scss +218 -0
  141. package/src/components/base/ui/style/dropdown-item.scss +0 -0
  142. package/src/components/base/ui/style/dropdown-menu.scss +0 -0
  143. package/src/components/base/ui/style/dropdown.scss +185 -0
  144. package/src/components/base/ui/style/form-item.scss +0 -0
  145. package/src/components/base/ui/style/form.scss +203 -0
  146. package/src/components/base/ui/style/function.scss +43 -0
  147. package/src/components/base/ui/style/icon.scss +1167 -0
  148. package/src/components/base/ui/style/image.scss +184 -0
  149. package/src/components/base/ui/style/index.scss +57 -0
  150. package/src/components/base/ui/style/input-number.scss +187 -0
  151. package/src/components/base/ui/style/input.scss +477 -0
  152. package/src/components/base/ui/style/menu-item-group.scss +0 -0
  153. package/src/components/base/ui/style/menu-item.scss +0 -0
  154. package/src/components/base/ui/style/menu.scss +294 -0
  155. package/src/components/base/ui/style/message-box.scss +231 -0
  156. package/src/components/base/ui/style/message.scss +120 -0
  157. package/src/components/base/ui/style/mixins.scss +196 -0
  158. package/src/components/base/ui/style/option-group.scss +42 -0
  159. package/src/components/base/ui/style/option.scss +36 -0
  160. package/src/components/base/ui/style/pagination.scss +295 -0
  161. package/src/components/base/ui/style/popover.scss +40 -0
  162. package/src/components/base/ui/style/popper.scss +102 -0
  163. package/src/components/base/ui/style/popup.scss +42 -0
  164. package/src/components/base/ui/style/progress.scss +141 -0
  165. package/src/components/base/ui/style/radio-button.scss +113 -0
  166. package/src/components/base/ui/style/radio-group.scss +9 -0
  167. package/src/components/base/ui/style/radio.scss +203 -0
  168. package/src/components/base/ui/style/ripple.scss +35 -0
  169. package/src/components/base/ui/style/row.scss +39 -0
  170. package/src/components/base/ui/style/scrollbar.scss +75 -0
  171. package/src/components/base/ui/style/select-dropdown.scss +59 -0
  172. package/src/components/base/ui/style/select.scss +154 -0
  173. package/src/components/base/ui/style/skeleton-item.scss +84 -0
  174. package/src/components/base/ui/style/skeleton.scss +40 -0
  175. package/src/components/base/ui/style/slider.scss +250 -0
  176. package/src/components/base/ui/style/switch.scss +116 -0
  177. package/src/components/base/ui/style/tabs.scss +602 -0
  178. package/src/components/base/ui/style/tag.scss +174 -0
  179. package/src/components/base/ui/style/tooltip.scss +146 -0
  180. package/src/components/base/ui/style/transition.scss +138 -0
  181. package/src/components/base/ui/style/upload.scss +603 -0
  182. package/src/components/base/ui/style/utils.scss +39 -0
  183. package/src/components/base/ui/style/var.scss +1007 -0
  184. package/src/components/base/ui/switch/index.vue +174 -0
  185. package/src/components/base/ui/tabs/tab-bar.vue +57 -0
  186. package/src/components/base/ui/tabs/tab-nav.vue +294 -0
  187. package/src/components/base/ui/tabs/tab-pane.vue +56 -0
  188. package/src/components/base/ui/tabs/tabs.vue +191 -0
  189. package/src/components/base/ui/tag/Tag.vue +60 -0
  190. package/src/components/base/ui/tooltip/tooltip.jsx +234 -0
  191. package/src/components/base/ui/upload/Index.vue +340 -0
  192. package/src/components/base/ui/upload/Upload.vue +216 -0
  193. package/src/components/base/ui/upload/UploadDragger.vue +70 -0
  194. package/src/components/base/ui/upload/UploadList.vue +100 -0
  195. package/src/components/base/ui/upload/ajax.js +85 -0
  196. package/src/components/base/ui/util/aria-dialog.js +90 -0
  197. package/src/components/base/ui/util/aria-utils.js +122 -0
  198. package/src/components/base/ui/util/clickoutside.js +76 -0
  199. package/src/components/base/ui/util/date-util.js +292 -0
  200. package/src/components/base/ui/util/date.js +370 -0
  201. package/src/components/base/ui/util/debounce.js +21 -0
  202. package/src/components/base/ui/util/deepmerge.js +100 -0
  203. package/src/components/base/ui/util/dom.js +215 -0
  204. package/src/components/base/ui/util/index.js +262 -0
  205. package/src/components/base/ui/util/menu/aria-menubar.js +14 -0
  206. package/src/components/base/ui/util/menu/aria-menuitem.js +49 -0
  207. package/src/components/base/ui/util/menu/aria-submenu.js +59 -0
  208. package/src/components/base/ui/util/merge.js +14 -0
  209. package/src/components/base/ui/util/popper.js +1235 -0
  210. package/src/components/base/ui/util/popup/index.js +218 -0
  211. package/src/components/base/ui/util/popup/popup-manager.js +194 -0
  212. package/src/components/base/ui/util/resize-events.js +32 -0
  213. package/src/components/base/ui/util/scroll-into-view.js +27 -0
  214. package/src/components/base/ui/util/scrollbar-width.js +29 -0
  215. package/src/components/base/ui/util/shared.js +7 -0
  216. package/src/components/base/ui/util/throttle.js +91 -0
  217. package/src/components/base/ui/util/types.js +24 -0
  218. package/src/components/base/ui/util/vdom.js +5 -0
  219. package/src/components/base/ui/util/vue-popper.js +188 -0
  220. package/src/components/normal/AggsItemH.vue +139 -0
  221. package/src/index.js +10 -0
  222. package/src/static/base-icons.ttf +0 -0
  223. package/src/static/base-icons.woff +0 -0
  224. package/src/static/label_bg.png +0 -0
  225. package/src/static/term-label-bg.png +0 -0
  226. package/src/style/app-article.scss +698 -0
  227. package/src/style/app-comment.scss +259 -0
  228. package/src/style/app-recommend.scss +48 -0
  229. package/src/style/app-richtext.scss +176 -0
  230. package/src/style/index.scss +523 -0
  231. package/vite.config.js +38 -0
@@ -0,0 +1,302 @@
1
+ <template>
2
+ <transition name="viewer-fade">
3
+ <div tabindex="-1" ref="base-image-viewer__wrapper" class="base-image-viewer__wrapper" :style="{ 'z-index': zIndex }">
4
+ <div class="base-image-viewer__mask"></div>
5
+ <!-- CLOSE -->
6
+ <span class="base-image-viewer__btn base-image-viewer__close" @click="hide">
7
+ <i class="base-icon-close"></i>
8
+ </span>
9
+ <!-- ARROW -->
10
+ <template v-if="!isSingle">
11
+ <span
12
+ class="base-image-viewer__btn base-image-viewer__prev"
13
+ :class="{ 'is-disabled': !infinite && isFirst }"
14
+ @click="prev">
15
+ <i class="base-icon-arrow-left"/>
16
+ </span>
17
+ <span
18
+ class="base-image-viewer__btn base-image-viewer__next"
19
+ :class="{ 'is-disabled': !infinite && isLast }"
20
+ @click="next">
21
+ <i class="base-icon-arrow-right"/>
22
+ </span>
23
+ </template>
24
+ <!-- ACTIONS -->
25
+ <div class="base-image-viewer__btn base-image-viewer__actions">
26
+ <div class="base-image-viewer__actions__inner">
27
+ <i class="base-icon-zoom-out" @click="handleActions('zoomOut')"></i>
28
+ <i class="base-icon-zoom-in" @click="handleActions('zoomIn')"></i>
29
+ <i class="base-image-viewer__actions__divider"></i>
30
+ <i :class="mode.icon" @click="toggleMode"></i>
31
+ <i class="base-image-viewer__actions__divider"></i>
32
+ <i class="base-icon-refresh-left" @click="handleActions('anticlocelise')"></i>
33
+ <i class="base-icon-refresh-right" @click="handleActions('clocelise')"></i>
34
+ </div>
35
+ </div>
36
+ <!-- CANVAS -->
37
+ <div class="base-image-viewer__canvas">
38
+ <img
39
+ v-for="(url, i) in urlList"
40
+ v-if="i === index"
41
+ ref="img"
42
+ class="base-image-viewer__img"
43
+ :key="url"
44
+ :src="currentImg"
45
+ :style="imgStyle"
46
+ @load="handleImgLoad"
47
+ @error="handleImgError"
48
+ @mousedown="handleMouseDown">
49
+ </div>
50
+ </div>
51
+ </transition>
52
+ </template>
53
+
54
+ <script>
55
+ import { on, off } from '../util/dom';
56
+ import { rafThrottle, isFirefox } from '../util';
57
+
58
+ const Mode = {
59
+ CONTAIN: {
60
+ name: 'contain',
61
+ icon: 'base-icon-full-screen'
62
+ },
63
+ ORIGINAL: {
64
+ name: 'original',
65
+ icon: 'base-icon-c-scale-to-original'
66
+ }
67
+ };
68
+
69
+ const mousewheelEventName = isFirefox() ? 'DOMMouseScroll' : 'mousewheel';
70
+
71
+ export default {
72
+ name: 'elImageViewer',
73
+
74
+ props: {
75
+ urlList: {
76
+ type: Array,
77
+ default: () => []
78
+ },
79
+ zIndex: {
80
+ type: Number,
81
+ default: 2000
82
+ },
83
+ onSwitch: {
84
+ type: Function,
85
+ default: () => {}
86
+ },
87
+ onClose: {
88
+ type: Function,
89
+ default: () => {}
90
+ },
91
+ initialIndex: {
92
+ type: Number,
93
+ default: 0
94
+ }
95
+ },
96
+
97
+ data() {
98
+ return {
99
+ index: this.initialIndex,
100
+ isShow: false,
101
+ infinite: true,
102
+ loading: false,
103
+ mode: Mode.CONTAIN,
104
+ transform: {
105
+ scale: 1,
106
+ deg: 0,
107
+ offsetX: 0,
108
+ offsetY: 0,
109
+ enableTransition: false
110
+ }
111
+ };
112
+ },
113
+ computed: {
114
+ isSingle() {
115
+ return this.urlList.length <= 1;
116
+ },
117
+ isFirst() {
118
+ return this.index === 0;
119
+ },
120
+ isLast() {
121
+ return this.index === this.urlList.length - 1;
122
+ },
123
+ currentImg() {
124
+ return this.urlList[this.index];
125
+ },
126
+ imgStyle() {
127
+ const { scale, deg, offsetX, offsetY, enableTransition } = this.transform;
128
+ const style = {
129
+ transform: `scale(${scale}) rotate(${deg}deg)`,
130
+ transition: enableTransition ? 'transform .3s' : '',
131
+ 'margin-left': `${offsetX}px`,
132
+ 'margin-top': `${offsetY}px`
133
+ };
134
+ if (this.mode === Mode.CONTAIN) {
135
+ style.maxWidth = style.maxHeight = '100%';
136
+ }
137
+ return style;
138
+ }
139
+ },
140
+ watch: {
141
+ index: {
142
+ handler: function(val) {
143
+ this.reset();
144
+ this.onSwitch(val);
145
+ }
146
+ },
147
+ currentImg(val) {
148
+ this.$nextTick(_ => {
149
+ const $img = this.$refs.img[0];
150
+ if (!$img.complete) {
151
+ this.loading = true;
152
+ }
153
+ });
154
+ }
155
+ },
156
+ methods: {
157
+ hide() {
158
+ this.deviceSupportUninstall();
159
+ this.onClose();
160
+ },
161
+ deviceSupportInstall() {
162
+ this._keyDownHandler = rafThrottle(e => {
163
+ const keyCode = e.keyCode;
164
+ switch (keyCode) {
165
+ // ESC
166
+ case 27:
167
+ this.hide();
168
+ break;
169
+ // SPACE
170
+ case 32:
171
+ this.toggleMode();
172
+ break;
173
+ // LEFT_ARROW
174
+ case 37:
175
+ this.prev();
176
+ break;
177
+ // UP_ARROW
178
+ case 38:
179
+ this.handleActions('zoomIn');
180
+ break;
181
+ // RIGHT_ARROW
182
+ case 39:
183
+ this.next();
184
+ break;
185
+ // DOWN_ARROW
186
+ case 40:
187
+ this.handleActions('zoomOut');
188
+ break;
189
+ }
190
+ });
191
+ this._mouseWheelHandler = rafThrottle(e => {
192
+ const delta = e.wheelDelta ? e.wheelDelta : -e.detail;
193
+ if (delta > 0) {
194
+ this.handleActions('zoomIn', {
195
+ zoomRate: 0.015,
196
+ enableTransition: false
197
+ });
198
+ } else {
199
+ this.handleActions('zoomOut', {
200
+ zoomRate: 0.015,
201
+ enableTransition: false
202
+ });
203
+ }
204
+ });
205
+ on(document, 'keydown', this._keyDownHandler);
206
+ on(document, mousewheelEventName, this._mouseWheelHandler);
207
+ },
208
+ deviceSupportUninstall() {
209
+ off(document, 'keydown', this._keyDownHandler);
210
+ off(document, mousewheelEventName, this._mouseWheelHandler);
211
+ this._keyDownHandler = null;
212
+ this._mouseWheelHandler = null;
213
+ },
214
+ handleImgLoad(e) {
215
+ this.loading = false;
216
+ },
217
+ handleImgError(e) {
218
+ this.loading = false;
219
+ e.target.alt = '加载失败';
220
+ },
221
+ handleMouseDown(e) {
222
+ if (this.loading || e.button !== 0) return;
223
+
224
+ const { offsetX, offsetY } = this.transform;
225
+ const startX = e.pageX;
226
+ const startY = e.pageY;
227
+ this._dragHandler = rafThrottle(ev => {
228
+ this.transform.offsetX = offsetX + ev.pageX - startX;
229
+ this.transform.offsetY = offsetY + ev.pageY - startY;
230
+ });
231
+ on(document, 'mousemove', this._dragHandler);
232
+ on(document, 'mouseup', ev => {
233
+ off(document, 'mousemove', this._dragHandler);
234
+ });
235
+
236
+ e.preventDefault();
237
+ },
238
+ reset() {
239
+ this.transform = {
240
+ scale: 1,
241
+ deg: 0,
242
+ offsetX: 0,
243
+ offsetY: 0,
244
+ enableTransition: false
245
+ };
246
+ },
247
+ toggleMode() {
248
+ if (this.loading) return;
249
+
250
+ const modeNames = Object.keys(Mode);
251
+ const modeValues = Object.values(Mode);
252
+ const index = modeValues.indexOf(this.mode);
253
+ const nextIndex = (index + 1) % modeNames.length;
254
+ this.mode = Mode[modeNames[nextIndex]];
255
+ this.reset();
256
+ },
257
+ prev() {
258
+ if (this.isFirst && !this.infinite) return;
259
+ const len = this.urlList.length;
260
+ this.index = (this.index - 1 + len) % len;
261
+ },
262
+ next() {
263
+ if (this.isLast && !this.infinite) return;
264
+ const len = this.urlList.length;
265
+ this.index = (this.index + 1) % len;
266
+ },
267
+ handleActions(action, options = {}) {
268
+ if (this.loading) return;
269
+ const { zoomRate, rotateDeg, enableTransition } = {
270
+ zoomRate: 0.2,
271
+ rotateDeg: 90,
272
+ enableTransition: true,
273
+ ...options
274
+ };
275
+ const { transform } = this;
276
+ switch (action) {
277
+ case 'zoomOut':
278
+ if (transform.scale > 0.2) {
279
+ transform.scale = parseFloat((transform.scale - zoomRate).toFixed(3));
280
+ }
281
+ break;
282
+ case 'zoomIn':
283
+ transform.scale = parseFloat((transform.scale + zoomRate).toFixed(3));
284
+ break;
285
+ case 'clocelise':
286
+ transform.deg += rotateDeg;
287
+ break;
288
+ case 'anticlocelise':
289
+ transform.deg -= rotateDeg;
290
+ break;
291
+ }
292
+ transform.enableTransition = enableTransition;
293
+ }
294
+ },
295
+ mounted() {
296
+ this.deviceSupportInstall();
297
+ // add tabindex then wrapper can be focusable via Javascript
298
+ // focus wrapper so arrow key can't cause inner scroll behavior underneath
299
+ this.$refs['base-image-viewer__wrapper'].focus();
300
+ }
301
+ };
302
+ </script>
@@ -0,0 +1,248 @@
1
+ <template>
2
+ <div class="base-image">
3
+ <slot v-if="loading" name="placeholder">
4
+ <div class="base-image__placeholder"></div>
5
+ </slot>
6
+ <slot v-else-if="error" name="error">
7
+ <div class="base-image__error">{{ t('base.image.error') }}</div>
8
+ </slot>
9
+ <img
10
+ v-else
11
+ class="base-image__inner"
12
+ v-bind="$attrs"
13
+ v-on="$listeners"
14
+ @click.prevent.stop="clickHandler"
15
+ :src="src"
16
+ :style="imageStyle"
17
+ :class="{ 'base-image__inner--center': alignCenter, 'base-image__preview': preview, 'HoverImage':hoverScale }">
18
+ <template v-if="preview">
19
+ <image-viewer :z-index="zIndex" :initial-index="imageIndex" v-if="showViewer" :on-close="closeViewer" :url-list="previewSrcList"/>
20
+ </template>
21
+ </div>
22
+ </template>
23
+
24
+ <script>
25
+ import ImageViewer from './image-viewer';
26
+ import Locale from '../mixin/locale';
27
+ import { on, off, getScrollContainer, isInContainer } from '../util/dom';
28
+ import { isString, isHtmlElement } from '../util/types';
29
+ import throttle from '../util/throttle';
30
+
31
+ const isSupportObjectFit = () => document.documentElement.style.objectFit !== undefined;
32
+
33
+ const ObjectFit = {
34
+ NONE: 'none',
35
+ CONTAIN: 'contain',
36
+ COVER: 'cover',
37
+ FILL: 'fill',
38
+ SCALE_DOWN: 'scale-down'
39
+ };
40
+
41
+ let prevOverflow = '';
42
+
43
+ export default {
44
+ name: 'BaseImage',
45
+
46
+ mixins: [Locale],
47
+ inheritAttrs: false,
48
+
49
+ components: {
50
+ ImageViewer
51
+ },
52
+
53
+ props: {
54
+ src: String,
55
+ fit: {
56
+ type: String,
57
+ default: 'cover'
58
+ },
59
+ lazy: Boolean,
60
+ scrollContainer: {},
61
+ previewSrcList: {
62
+ type: Array,
63
+ default: () => []
64
+ },
65
+ zIndex: {
66
+ type: Number,
67
+ default: 2000
68
+ },
69
+ hoverScale: {
70
+ type: Boolean,
71
+ default: false
72
+ }
73
+ },
74
+
75
+ data() {
76
+ return {
77
+ loading: true,
78
+ error: false,
79
+ show: !this.lazy,
80
+ imageWidth: 0,
81
+ imageHeight: 0,
82
+ showViewer: false
83
+ };
84
+ },
85
+
86
+ computed: {
87
+ imageStyle() {
88
+ const { fit } = this;
89
+ if (!this.$isServer && fit) {
90
+ return isSupportObjectFit()
91
+ ? { 'object-fit': fit }
92
+ : this.getImageStyle(fit);
93
+ }
94
+ return {};
95
+ },
96
+ alignCenter() {
97
+ return !this.$isServer && !isSupportObjectFit() && this.fit !== ObjectFit.FILL;
98
+ },
99
+ preview() {
100
+ const { previewSrcList } = this;
101
+ return Array.isArray(previewSrcList) && previewSrcList.length > 0;
102
+ },
103
+ imageIndex() {
104
+ let previewIndex = 0;
105
+ const srcIndex = this.previewSrcList.indexOf(this.src);
106
+ if (srcIndex >= 0) {
107
+ previewIndex = srcIndex;
108
+ }
109
+ return previewIndex;
110
+ }
111
+ },
112
+
113
+ watch: {
114
+ src(val) {
115
+ this.show && this.loadImage();
116
+ },
117
+ show(val) {
118
+ val && this.loadImage();
119
+ }
120
+ },
121
+
122
+ mounted() {
123
+ if (this.lazy) {
124
+ this.addLazyLoadListener();
125
+ } else {
126
+ this.loadImage();
127
+ }
128
+ },
129
+
130
+ beforeDestroy() {
131
+ this.lazy && this.removeLazyLoadListener();
132
+ },
133
+
134
+ methods: {
135
+ loadImage() {
136
+ if (this.$isServer) return;
137
+
138
+ // reset status
139
+ this.loading = true;
140
+ this.error = false;
141
+
142
+ const img = new Image();
143
+ img.onload = e => this.handleLoad(e, img);
144
+ img.onerror = this.handleError.bind(this);
145
+
146
+ // bind html attrs
147
+ // so it can behave consistently
148
+ Object.keys(this.$attrs)
149
+ .forEach((key) => {
150
+ const value = this.$attrs[key];
151
+ img.setAttribute(key, value);
152
+ });
153
+ img.src = this.src;
154
+ },
155
+ handleLoad(e, img) {
156
+ this.imageWidth = img.width;
157
+ this.imageHeight = img.height;
158
+ this.loading = false;
159
+ this.error = false;
160
+ },
161
+ handleError(e) {
162
+ this.loading = false;
163
+ this.error = true;
164
+ this.$emit('error', e);
165
+ },
166
+ handleLazyLoad() {
167
+ if (isInContainer(this.$el, this._scrollContainer)) {
168
+ this.show = true;
169
+ this.removeLazyLoadListener();
170
+ }
171
+ },
172
+ addLazyLoadListener() {
173
+ if (this.$isServer) return;
174
+
175
+ const { scrollContainer } = this;
176
+ let _scrollContainer = null;
177
+
178
+ if (isHtmlElement(scrollContainer)) {
179
+ _scrollContainer = scrollContainer;
180
+ } else if (isString(scrollContainer)) {
181
+ _scrollContainer = document.querySelector(scrollContainer);
182
+ } else {
183
+ _scrollContainer = getScrollContainer(this.$el);
184
+ }
185
+
186
+ if (_scrollContainer) {
187
+ this._scrollContainer = _scrollContainer;
188
+ this._lazyLoadHandler = throttle(200, this.handleLazyLoad);
189
+ on(_scrollContainer, 'scroll', this._lazyLoadHandler);
190
+ this.handleLazyLoad();
191
+ }
192
+ },
193
+ removeLazyLoadListener() {
194
+ const { _scrollContainer, _lazyLoadHandler } = this;
195
+
196
+ if (this.$isServer || !_scrollContainer || !_lazyLoadHandler) return;
197
+
198
+ off(_scrollContainer, 'scroll', _lazyLoadHandler);
199
+ this._scrollContainer = null;
200
+ this._lazyLoadHandler = null;
201
+ },
202
+ /**
203
+ * simulate object-fit behavior to compatible with IE11 and other browsers which not support object-fit
204
+ */
205
+ getImageStyle(fit) {
206
+ const { imageWidth, imageHeight } = this;
207
+ const {
208
+ clientWidth: containerWidth,
209
+ clientHeight: containerHeight
210
+ } = this.$el;
211
+
212
+ if (!imageWidth || !imageHeight || !containerWidth || !containerHeight) return {};
213
+
214
+ const vertical = imageWidth / imageHeight < 1;
215
+
216
+ if (fit === ObjectFit.SCALE_DOWN) {
217
+ const isSmaller = imageWidth < containerWidth && imageHeight < containerHeight;
218
+ fit = isSmaller ? ObjectFit.NONE : ObjectFit.CONTAIN;
219
+ }
220
+
221
+ switch (fit) {
222
+ case ObjectFit.NONE:
223
+ return { width: 'auto', height: 'auto' };
224
+ case ObjectFit.CONTAIN:
225
+ return vertical ? { width: 'auto' } : { height: 'auto' };
226
+ case ObjectFit.COVER:
227
+ return vertical ? { height: 'auto' } : { width: 'auto' };
228
+ default:
229
+ return {};
230
+ }
231
+ },
232
+ clickHandler() {
233
+ // don't show viewer when preview is false
234
+ if (!this.preview) {
235
+ return;
236
+ }
237
+ // prevent body scroll
238
+ prevOverflow = document.body.style.overflow;
239
+ document.body.style.overflow = 'hidden';
240
+ this.showViewer = true;
241
+ },
242
+ closeViewer() {
243
+ document.body.style.overflow = prevOverflow;
244
+ this.showViewer = false;
245
+ }
246
+ }
247
+ };
248
+ </script>