@mdsfe/mds-ui 0.2.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 (153) hide show
  1. package/CHANGELOG.md +778 -0
  2. package/LICENSE +21 -0
  3. package/README.md +106 -0
  4. package/dist/_locale/index.js +18 -0
  5. package/dist/_locale/zh-CN.js +123 -0
  6. package/dist/_mixin/emitter.js +35 -0
  7. package/dist/_mixin/focus.js +13 -0
  8. package/dist/_mixin/locale.js +17 -0
  9. package/dist/_mixin/popper.js +192 -0
  10. package/dist/_mixin/tooltip.js +218 -0
  11. package/dist/_util/__test__/switchcase.test.js +43 -0
  12. package/dist/_util/autoprefixer.js +249 -0
  13. package/dist/_util/clickoutside.js +79 -0
  14. package/dist/_util/date.js +368 -0
  15. package/dist/_util/dateUtil.js +311 -0
  16. package/dist/_util/dom.js +240 -0
  17. package/dist/_util/getRequestAnimationFrame.js +50 -0
  18. package/dist/_util/getScroll.js +21 -0
  19. package/dist/_util/loaders/loaders.css.js +52 -0
  20. package/dist/_util/loaders/loading.js +53 -0
  21. package/dist/_util/merge.js +18 -0
  22. package/dist/_util/popper.js +1261 -0
  23. package/dist/_util/popup/index.js +232 -0
  24. package/dist/_util/popup/popup-manager.js +205 -0
  25. package/dist/_util/proptype.js +12 -0
  26. package/dist/_util/repeatClick.js +30 -0
  27. package/dist/_util/resize.js +61 -0
  28. package/dist/_util/resizeEvent.js +59 -0
  29. package/dist/_util/scrollIntoView.js +38 -0
  30. package/dist/_util/scrollbar-width.js +37 -0
  31. package/dist/_util/soda.js +54 -0
  32. package/dist/_util/switchcase.js +22 -0
  33. package/dist/_util/throttleByAnimationFrame.js +70 -0
  34. package/dist/_util/tree/node.js +412 -0
  35. package/dist/_util/tree/tree.js +410 -0
  36. package/dist/_util/util.js +166 -0
  37. package/dist/_util/vue-popper.js +213 -0
  38. package/dist/affix.js +509 -0
  39. package/dist/anchor.js +522 -0
  40. package/dist/avatar.js +437 -0
  41. package/dist/backtop.js +469 -0
  42. package/dist/badge.js +439 -0
  43. package/dist/bordershadow.js +310 -0
  44. package/dist/breadcrumb.js +434 -0
  45. package/dist/button.js +579 -0
  46. package/dist/card.js +514 -0
  47. package/dist/carousel.js +1326 -0
  48. package/dist/cascaderpanel.js +2320 -0
  49. package/dist/checkbox.js +681 -0
  50. package/dist/col.js +546 -0
  51. package/dist/collapse.js +671 -0
  52. package/dist/color.js +306 -0
  53. package/dist/datepicker.js +8089 -0
  54. package/dist/divider.js +346 -0
  55. package/dist/drawer.js +652 -0
  56. package/dist/dropdown.js +687 -0
  57. package/dist/empty.js +416 -0
  58. package/dist/font.js +306 -0
  59. package/dist/form.js +878 -0
  60. package/dist/icon.js +401 -0
  61. package/dist/index.js +1 -0
  62. package/dist/input.js +1251 -0
  63. package/dist/inputnumber.js +689 -0
  64. package/dist/layout.js +786 -0
  65. package/dist/list.js +789 -0
  66. package/dist/loading.js +430 -0
  67. package/dist/mds-ui.min.css +7 -0
  68. package/dist/mds-ui.min.js +64911 -0
  69. package/dist/menu.js +1131 -0
  70. package/dist/message.js +1016 -0
  71. package/dist/modal.js +895 -0
  72. package/dist/notification.js +818 -0
  73. package/dist/pagination.js +1213 -0
  74. package/dist/popconfirm.js +336 -0
  75. package/dist/popover.js +206 -0
  76. package/dist/progress.js +1023 -0
  77. package/dist/radio.js +760 -0
  78. package/dist/rate.js +765 -0
  79. package/dist/row.js +546 -0
  80. package/dist/select.js +4950 -0
  81. package/dist/slider.js +1411 -0
  82. package/dist/slottable.js +1414 -0
  83. package/dist/steps.js +546 -0
  84. package/dist/style/affix.css +5524 -0
  85. package/dist/style/anchor.css +5572 -0
  86. package/dist/style/avatar.css +5587 -0
  87. package/dist/style/backtop.css +34 -0
  88. package/dist/style/badge.css +5655 -0
  89. package/dist/style/bordershadow.css +5601 -0
  90. package/dist/style/breadcrumb.css +5551 -0
  91. package/dist/style/button.css +7679 -0
  92. package/dist/style/card.css +5670 -0
  93. package/dist/style/carousel.css +5731 -0
  94. package/dist/style/cascaderpanel.css +125 -0
  95. package/dist/style/checkbox.css +5700 -0
  96. package/dist/style/col.css +8121 -0
  97. package/dist/style/collapse.css +5593 -0
  98. package/dist/style/color.css +6136 -0
  99. package/dist/style/datepicker.css +5977 -0
  100. package/dist/style/divider.css +5558 -0
  101. package/dist/style/drawer.css +7979 -0
  102. package/dist/style/dropdown.css +7950 -0
  103. package/dist/style/empty.css +5563 -0
  104. package/dist/style/font.css +5559 -0
  105. package/dist/style/form.css +5662 -0
  106. package/dist/style/icon.css +5538 -0
  107. package/dist/style/input.css +6256 -0
  108. package/dist/style/inputnumber.css +5828 -0
  109. package/dist/style/layout.css +5572 -0
  110. package/dist/style/list.css +5655 -0
  111. package/dist/style/loading.css +5540 -0
  112. package/dist/style/menu.css +6183 -0
  113. package/dist/style/message.css +194 -0
  114. package/dist/style/modal.css +5637 -0
  115. package/dist/style/notification.css +5706 -0
  116. package/dist/style/pagination.css +6683 -0
  117. package/dist/style/popconfirm.css +7951 -0
  118. package/dist/style/popover.css +5727 -0
  119. package/dist/style/progress.css +5714 -0
  120. package/dist/style/radio.css +5769 -0
  121. package/dist/style/rate.css +5616 -0
  122. package/dist/style/row.css +8121 -0
  123. package/dist/style/select.css +5729 -0
  124. package/dist/style/slider.css +5594 -0
  125. package/dist/style/slottable.css +5831 -0
  126. package/dist/style/steps.css +6100 -0
  127. package/dist/style/switch.css +5624 -0
  128. package/dist/style/table.css +8392 -0
  129. package/dist/style/tabs.css +6047 -0
  130. package/dist/style/tag.css +5935 -0
  131. package/dist/style/text.css +5636 -0
  132. package/dist/style/timeline.css +5602 -0
  133. package/dist/style/timepicker.css +5904 -0
  134. package/dist/style/tooltip.css +5686 -0
  135. package/dist/style/transfer.css +101 -0
  136. package/dist/style/transition.css +1417 -0
  137. package/dist/style/tree.css +5598 -0
  138. package/dist/style/typography.css +5640 -0
  139. package/dist/style/upload.css +5834 -0
  140. package/dist/switch.js +448 -0
  141. package/dist/table.js +3809 -0
  142. package/dist/tabs.js +1273 -0
  143. package/dist/tag.js +478 -0
  144. package/dist/text.js +1100 -0
  145. package/dist/timeline.js +495 -0
  146. package/dist/timepicker.js +1567 -0
  147. package/dist/tooltip.js +179 -0
  148. package/dist/transfer.js +981 -0
  149. package/dist/transition.js +246 -0
  150. package/dist/tree.js +1866 -0
  151. package/dist/typography.js +469 -0
  152. package/dist/upload.js +1990 -0
  153. package/package.json +144 -0
@@ -0,0 +1,687 @@
1
+ (function webpackUniversalModuleDefinition(root, factory) {
2
+ if(typeof exports === 'object' && typeof module === 'object')
3
+ module.exports = factory(require("./_util/proptype"), require("./icon"), require("./button"), require("./transition"), require("./_mixin/popper"));
4
+ else if(typeof define === 'function' && define.amd)
5
+ define(["./_util/proptype", "./icon", "./button", "./transition", "./_mixin/popper"], factory);
6
+ else {
7
+ var a = typeof exports === 'object' ? factory(require("./_util/proptype"), require("./icon"), require("./button"), require("./transition"), require("./_mixin/popper")) : factory(root["./_util/proptype"], root["./icon"], root["./button"], root["./transition"], root["./_mixin/popper"]);
8
+ for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
9
+ }
10
+ })(window, function(__WEBPACK_EXTERNAL_MODULE__3__, __WEBPACK_EXTERNAL_MODULE__4__, __WEBPACK_EXTERNAL_MODULE__7__, __WEBPACK_EXTERNAL_MODULE__13__, __WEBPACK_EXTERNAL_MODULE__44__) {
11
+ return /******/ (function(modules) { // webpackBootstrap
12
+ /******/ // The module cache
13
+ /******/ var installedModules = {};
14
+ /******/
15
+ /******/ // The require function
16
+ /******/ function __webpack_require__(moduleId) {
17
+ /******/
18
+ /******/ // Check if module is in cache
19
+ /******/ if(installedModules[moduleId]) {
20
+ /******/ return installedModules[moduleId].exports;
21
+ /******/ }
22
+ /******/ // Create a new module (and put it into the cache)
23
+ /******/ var module = installedModules[moduleId] = {
24
+ /******/ i: moduleId,
25
+ /******/ l: false,
26
+ /******/ exports: {}
27
+ /******/ };
28
+ /******/
29
+ /******/ // Execute the module function
30
+ /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
31
+ /******/
32
+ /******/ // Flag the module as loaded
33
+ /******/ module.l = true;
34
+ /******/
35
+ /******/ // Return the exports of the module
36
+ /******/ return module.exports;
37
+ /******/ }
38
+ /******/
39
+ /******/
40
+ /******/ // expose the modules object (__webpack_modules__)
41
+ /******/ __webpack_require__.m = modules;
42
+ /******/
43
+ /******/ // expose the module cache
44
+ /******/ __webpack_require__.c = installedModules;
45
+ /******/
46
+ /******/ // define getter function for harmony exports
47
+ /******/ __webpack_require__.d = function(exports, name, getter) {
48
+ /******/ if(!__webpack_require__.o(exports, name)) {
49
+ /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
50
+ /******/ }
51
+ /******/ };
52
+ /******/
53
+ /******/ // define __esModule on exports
54
+ /******/ __webpack_require__.r = function(exports) {
55
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
56
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
57
+ /******/ }
58
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
59
+ /******/ };
60
+ /******/
61
+ /******/ // create a fake namespace object
62
+ /******/ // mode & 1: value is a module id, require it
63
+ /******/ // mode & 2: merge all properties of value into the ns
64
+ /******/ // mode & 4: return value when already ns object
65
+ /******/ // mode & 8|1: behave like require
66
+ /******/ __webpack_require__.t = function(value, mode) {
67
+ /******/ if(mode & 1) value = __webpack_require__(value);
68
+ /******/ if(mode & 8) return value;
69
+ /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
70
+ /******/ var ns = Object.create(null);
71
+ /******/ __webpack_require__.r(ns);
72
+ /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
73
+ /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
74
+ /******/ return ns;
75
+ /******/ };
76
+ /******/
77
+ /******/ // getDefaultExport function for compatibility with non-harmony modules
78
+ /******/ __webpack_require__.n = function(module) {
79
+ /******/ var getter = module && module.__esModule ?
80
+ /******/ function getDefault() { return module['default']; } :
81
+ /******/ function getModuleExports() { return module; };
82
+ /******/ __webpack_require__.d(getter, 'a', getter);
83
+ /******/ return getter;
84
+ /******/ };
85
+ /******/
86
+ /******/ // Object.prototype.hasOwnProperty.call
87
+ /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
88
+ /******/
89
+ /******/ // __webpack_public_path__
90
+ /******/ __webpack_require__.p = "/dist/";
91
+ /******/
92
+ /******/
93
+ /******/ // Load entry module and return exports
94
+ /******/ return __webpack_require__(__webpack_require__.s = 99);
95
+ /******/ })
96
+ /************************************************************************/
97
+ /******/ ({
98
+
99
+ /***/ 0:
100
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
101
+
102
+ "use strict";
103
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
104
+ /* globals __VUE_SSR_CONTEXT__ */
105
+
106
+ // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
107
+ // This module is a runtime utility for cleaner component module output and will
108
+ // be included in the final webpack user bundle.
109
+
110
+ function normalizeComponent (
111
+ scriptExports,
112
+ render,
113
+ staticRenderFns,
114
+ functionalTemplate,
115
+ injectStyles,
116
+ scopeId,
117
+ moduleIdentifier, /* server only */
118
+ shadowMode /* vue-cli only */
119
+ ) {
120
+ // Vue.extend constructor export interop
121
+ var options = typeof scriptExports === 'function'
122
+ ? scriptExports.options
123
+ : scriptExports
124
+
125
+ // render functions
126
+ if (render) {
127
+ options.render = render
128
+ options.staticRenderFns = staticRenderFns
129
+ options._compiled = true
130
+ }
131
+
132
+ // functional template
133
+ if (functionalTemplate) {
134
+ options.functional = true
135
+ }
136
+
137
+ // scopedId
138
+ if (scopeId) {
139
+ options._scopeId = 'data-v-' + scopeId
140
+ }
141
+
142
+ var hook
143
+ if (moduleIdentifier) { // server build
144
+ hook = function (context) {
145
+ // 2.3 injection
146
+ context =
147
+ context || // cached call
148
+ (this.$vnode && this.$vnode.ssrContext) || // stateful
149
+ (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
150
+ // 2.2 with runInNewContext: true
151
+ if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
152
+ context = __VUE_SSR_CONTEXT__
153
+ }
154
+ // inject component styles
155
+ if (injectStyles) {
156
+ injectStyles.call(this, context)
157
+ }
158
+ // register component module identifier for async chunk inferrence
159
+ if (context && context._registeredComponents) {
160
+ context._registeredComponents.add(moduleIdentifier)
161
+ }
162
+ }
163
+ // used by ssr in case component is cached and beforeCreate
164
+ // never gets called
165
+ options._ssrRegister = hook
166
+ } else if (injectStyles) {
167
+ hook = shadowMode
168
+ ? function () {
169
+ injectStyles.call(
170
+ this,
171
+ (options.functional ? this.parent : this).$root.$options.shadowRoot
172
+ )
173
+ }
174
+ : injectStyles
175
+ }
176
+
177
+ if (hook) {
178
+ if (options.functional) {
179
+ // for template-only hot-reload because in that case the render fn doesn't
180
+ // go through the normalizer
181
+ options._injectStyles = hook
182
+ // register for functional component in vue file
183
+ var originalRender = options.render
184
+ options.render = function renderWithStyleInjection (h, context) {
185
+ hook.call(context)
186
+ return originalRender(h, context)
187
+ }
188
+ } else {
189
+ // inject component registration as beforeCreate hook
190
+ var existing = options.beforeCreate
191
+ options.beforeCreate = existing
192
+ ? [].concat(existing, hook)
193
+ : [hook]
194
+ }
195
+ }
196
+
197
+ return {
198
+ exports: scriptExports,
199
+ options: options
200
+ }
201
+ }
202
+
203
+
204
+ /***/ }),
205
+
206
+ /***/ 13:
207
+ /***/ (function(module, exports) {
208
+
209
+ module.exports = __WEBPACK_EXTERNAL_MODULE__13__;
210
+
211
+ /***/ }),
212
+
213
+ /***/ 131:
214
+ /***/ (function(module, exports) {
215
+
216
+ // removed by extract-text-webpack-plugin
217
+
218
+ /***/ }),
219
+
220
+ /***/ 149:
221
+ /***/ (function(module, exports) {
222
+
223
+ // removed by extract-text-webpack-plugin
224
+
225
+ /***/ }),
226
+
227
+ /***/ 163:
228
+ /***/ (function(module, exports) {
229
+
230
+ // removed by extract-text-webpack-plugin
231
+
232
+ /***/ }),
233
+
234
+ /***/ 3:
235
+ /***/ (function(module, exports) {
236
+
237
+ module.exports = __WEBPACK_EXTERNAL_MODULE__3__;
238
+
239
+ /***/ }),
240
+
241
+ /***/ 33:
242
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
243
+
244
+ "use strict";
245
+ /* harmony import */ var _style_index_less__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(131);
246
+ /* harmony import */ var _style_index_less__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_style_index_less__WEBPACK_IMPORTED_MODULE_0__);
247
+ /* harmony import */ var _index_less__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(149);
248
+ /* harmony import */ var _index_less__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_index_less__WEBPACK_IMPORTED_MODULE_1__);
249
+
250
+
251
+
252
+ /***/ }),
253
+
254
+ /***/ 4:
255
+ /***/ (function(module, exports) {
256
+
257
+ module.exports = __WEBPACK_EXTERNAL_MODULE__4__;
258
+
259
+ /***/ }),
260
+
261
+ /***/ 44:
262
+ /***/ (function(module, exports) {
263
+
264
+ module.exports = __WEBPACK_EXTERNAL_MODULE__44__;
265
+
266
+ /***/ }),
267
+
268
+ /***/ 7:
269
+ /***/ (function(module, exports) {
270
+
271
+ module.exports = __WEBPACK_EXTERNAL_MODULE__7__;
272
+
273
+ /***/ }),
274
+
275
+ /***/ 99:
276
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
277
+
278
+ "use strict";
279
+ // ESM COMPAT FLAG
280
+ __webpack_require__.r(__webpack_exports__);
281
+
282
+ // EXTERNAL MODULE: ./components/style/index.less
283
+ var style = __webpack_require__(131);
284
+
285
+ // EXTERNAL MODULE: ./components/dropdown/style/index.less
286
+ var dropdown_style = __webpack_require__(163);
287
+
288
+ // EXTERNAL MODULE: ./components/button/style/index.js
289
+ var button_style = __webpack_require__(33);
290
+
291
+ // CONCATENATED MODULE: ./components/dropdown/style/index.js
292
+
293
+
294
+
295
+ // style dependencies
296
+
297
+ // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./components/dropdown/dropdown.vue?vue&type=template&id=30153d24&
298
+ var render = function () {
299
+ var _vm = this
300
+ var _h = _vm.$createElement
301
+ var _c = _vm._self._c || _h
302
+ return _c(
303
+ _vm.isButton ? "mds-button" : "span",
304
+ { tag: "component", attrs: { type: _vm.type, disabled: _vm.disabled } },
305
+ [
306
+ _vm.isButton
307
+ ? _c("mds-icon", {
308
+ class: [_vm.prefixCls + "-icon"],
309
+ attrs: { type: "line-edit" },
310
+ })
311
+ : _vm._t("default"),
312
+ _c("mds-transition", { attrs: { type: "slide", motion: _vm.motion } }, [
313
+ _c(
314
+ "div",
315
+ {
316
+ directives: [
317
+ {
318
+ name: "show",
319
+ rawName: "v-show",
320
+ value: _vm.visible,
321
+ expression: "visible",
322
+ },
323
+ ],
324
+ ref: "overlay",
325
+ class: _vm.classes,
326
+ },
327
+ [_vm._t("overlay")],
328
+ 2
329
+ ),
330
+ ]),
331
+ ],
332
+ 2
333
+ )
334
+ }
335
+ var staticRenderFns = []
336
+ render._withStripped = true
337
+
338
+
339
+ // CONCATENATED MODULE: ./components/dropdown/dropdown.vue?vue&type=template&id=30153d24&
340
+
341
+ // EXTERNAL MODULE: external "./transition"
342
+ var external_transition_ = __webpack_require__(13);
343
+ var external_transition_default = /*#__PURE__*/__webpack_require__.n(external_transition_);
344
+
345
+ // EXTERNAL MODULE: external "./button"
346
+ var external_button_ = __webpack_require__(7);
347
+ var external_button_default = /*#__PURE__*/__webpack_require__.n(external_button_);
348
+
349
+ // EXTERNAL MODULE: external "./icon"
350
+ var external_icon_ = __webpack_require__(4);
351
+ var external_icon_default = /*#__PURE__*/__webpack_require__.n(external_icon_);
352
+
353
+ // EXTERNAL MODULE: external "./_mixin/popper"
354
+ var popper_ = __webpack_require__(44);
355
+ var popper_default = /*#__PURE__*/__webpack_require__.n(popper_);
356
+
357
+ // EXTERNAL MODULE: external "./_util/proptype"
358
+ var proptype_ = __webpack_require__(3);
359
+
360
+ // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./components/dropdown/dropdown.vue?vue&type=script&lang=js&
361
+ //
362
+ //
363
+ //
364
+ //
365
+ //
366
+ //
367
+ //
368
+ //
369
+ //
370
+ //
371
+ //
372
+ //
373
+ //
374
+ //
375
+ //
376
+ //
377
+ //
378
+ //
379
+
380
+
381
+
382
+
383
+
384
+
385
+
386
+ /* harmony default export */ var dropdownvue_type_script_lang_js_ = ({
387
+ name: 'MdsDropdown',
388
+ props: {
389
+ prefixCls: {
390
+ type: String,
391
+ default: 'mds-dropdown'
392
+ },
393
+ disabled: {
394
+ type: Boolean,
395
+ default: false
396
+ },
397
+ isButton: {
398
+ type: Boolean,
399
+ default: false
400
+ },
401
+ trigger: {
402
+ type: String,
403
+ default: 'hover',
404
+ validator: function validator(value) {
405
+ return Object(proptype_["oneOf"])(value, ['hover', 'click']);
406
+ }
407
+ },
408
+ type: {
409
+ type: String,
410
+ default: 'primary',
411
+ validator: function validator(value) {
412
+ return Object(proptype_["oneOf"])(value, ['primary', 'dashed', 'danger', 'default']);
413
+ }
414
+ }
415
+ },
416
+ data: function data() {
417
+ return {
418
+ timer: null,
419
+ popperModifiers: {
420
+ offset: {
421
+ offset: '0, 5px'
422
+ }
423
+ }
424
+ };
425
+ },
426
+
427
+ mixins: [popper_default.a],
428
+ computed: {
429
+ classes: function classes() {
430
+ var prefixCls = this.prefixCls;
431
+ return [prefixCls].concat(this.placementCls);
432
+ },
433
+ motion: function motion() {
434
+ return this.placement.indexOf('top') > -1 ? 'down' : 'up';
435
+ }
436
+ },
437
+ components: {
438
+ MdsTransition: external_transition_default.a,
439
+ MdsButton: external_button_default.a,
440
+ MdsIcon: external_icon_default.a
441
+ },
442
+ methods: {
443
+ show: function show() {
444
+ clearTimeout(this.timer);
445
+ this.visible = true;
446
+ },
447
+ hide: function hide() {
448
+ var _this = this;
449
+
450
+ clearTimeout(this.timer);
451
+ this.timer = setTimeout(function () {
452
+ _this.visible = false;
453
+ }, 150);
454
+ },
455
+ toggle: function toggle() {
456
+ this.visible = !this.visible;
457
+ },
458
+
459
+ /**
460
+ * 点击其他空白位置需要关闭浮层
461
+ * @param e
462
+ */
463
+ clickDocument: function clickDocument(e) {
464
+ if (!this.visible || !this.$el || !this.reference || !this.popper || this.$el.contains(e.target) || this.reference.contains(e.target) || this.popper.contains(e.target)) return;
465
+ this.hide();
466
+ }
467
+ },
468
+ beforeMount: function beforeMount() {
469
+ var _this2 = this;
470
+
471
+ this.$slots.overlay = this.$slots.overlay.map(function (vnode) {
472
+ vnode.componentOptions.propsData = {
473
+ prefixCls: _this2.prefixCls + '-menu',
474
+ selectable: false
475
+ };
476
+ return vnode;
477
+ });
478
+ },
479
+ mounted: function mounted() {
480
+ var overlay = this.$refs.overlay;
481
+ var dropdown = this.isButton ? this.$el : this.$slots.default[0].elm;
482
+
483
+ if (this.trigger === 'click') {
484
+ dropdown.addEventListener('click', this.toggle);
485
+ document.addEventListener('click', this.clickDocument);
486
+ } else {
487
+ dropdown.addEventListener('mouseenter', this.show);
488
+ dropdown.addEventListener('mouseleave', this.hide);
489
+ overlay.addEventListener('mouseenter', this.show);
490
+ overlay.addEventListener('mouseleave', this.hide);
491
+ }
492
+ overlay.addEventListener('click', this.hide);
493
+
494
+ this.popper = overlay;
495
+ this.reference = dropdown;
496
+ }
497
+ });
498
+ // CONCATENATED MODULE: ./components/dropdown/dropdown.vue?vue&type=script&lang=js&
499
+ /* harmony default export */ var dropdown_dropdownvue_type_script_lang_js_ = (dropdownvue_type_script_lang_js_);
500
+ // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
501
+ var componentNormalizer = __webpack_require__(0);
502
+
503
+ // CONCATENATED MODULE: ./components/dropdown/dropdown.vue
504
+
505
+
506
+
507
+
508
+
509
+ /* normalize component */
510
+
511
+ var component = Object(componentNormalizer["a" /* default */])(
512
+ dropdown_dropdownvue_type_script_lang_js_,
513
+ render,
514
+ staticRenderFns,
515
+ false,
516
+ null,
517
+ null,
518
+ null
519
+
520
+ )
521
+
522
+ /* hot reload */
523
+ if (false) { var api; }
524
+ component.options.__file = "components/dropdown/dropdown.vue"
525
+ /* harmony default export */ var dropdown = (component.exports);
526
+ // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./components/dropdown/dropdown-button.vue?vue&type=template&id=2dcfc6aa&
527
+ var dropdown_buttonvue_type_template_id_2dcfc6aa_render = function () {
528
+ var _vm = this
529
+ var _h = _vm.$createElement
530
+ var _c = _vm._self._c || _h
531
+ return _c(
532
+ "mds-button-group",
533
+ { class: _vm.prefixCls },
534
+ [
535
+ _c(
536
+ "mds-button",
537
+ {
538
+ attrs: { type: _vm.type, disabled: _vm.disabled },
539
+ on: { click: _vm.handleClick },
540
+ },
541
+ [_vm._t("default")],
542
+ 2
543
+ ),
544
+ _c(
545
+ "mds-dropdown",
546
+ {
547
+ attrs: {
548
+ placement: _vm.placement,
549
+ trigger: _vm.trigger,
550
+ "is-button": true,
551
+ type: _vm.type,
552
+ disabled: _vm.disabled,
553
+ },
554
+ },
555
+ [_c("template", { slot: "overlay" }, [_vm._t("overlay")], 2)],
556
+ 2
557
+ ),
558
+ ],
559
+ 1
560
+ )
561
+ }
562
+ var dropdown_buttonvue_type_template_id_2dcfc6aa_staticRenderFns = []
563
+ dropdown_buttonvue_type_template_id_2dcfc6aa_render._withStripped = true
564
+
565
+
566
+ // CONCATENATED MODULE: ./components/dropdown/dropdown-button.vue?vue&type=template&id=2dcfc6aa&
567
+
568
+ // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./components/dropdown/dropdown-button.vue?vue&type=script&lang=js&
569
+ //
570
+ //
571
+ //
572
+ //
573
+ //
574
+ //
575
+ //
576
+ //
577
+ //
578
+ //
579
+ //
580
+ //
581
+ //
582
+ //
583
+ //
584
+ //
585
+ //
586
+ //
587
+ //
588
+ //
589
+ //
590
+
591
+
592
+
593
+
594
+
595
+
596
+ var MdsButtonGroup = external_button_default.a.Group;
597
+
598
+ /* harmony default export */ var dropdown_buttonvue_type_script_lang_js_ = ({
599
+ name: 'MdsDropdownButton',
600
+ props: {
601
+ prefixCls: {
602
+ type: String,
603
+ default: 'mds-dropdown-button'
604
+ },
605
+ disabled: {
606
+ type: Boolean,
607
+ default: false
608
+ },
609
+ placement: {
610
+ type: String,
611
+ default: 'bottomRight'
612
+ },
613
+ size: {
614
+ type: String,
615
+ default: '',
616
+ validator: function validator(value) {
617
+ return Object(proptype_["oneOf"])(value, ['small', 'large', '', 'large-small']);
618
+ }
619
+ },
620
+ trigger: {
621
+ type: String,
622
+ default: 'hover',
623
+ validator: function validator(value) {
624
+ return Object(proptype_["oneOf"])(value, ['hover', 'click']);
625
+ }
626
+ },
627
+ type: {
628
+ type: String,
629
+ validator: function validator(value) {
630
+ return Object(proptype_["oneOf"])(value, ['primary', 'dashed', 'danger', 'default']);
631
+ }
632
+ }
633
+ },
634
+ components: {
635
+ MdsIcon: external_icon_default.a,
636
+ MdsButton: external_button_default.a,
637
+ MdsButtonGroup: MdsButtonGroup,
638
+ MdsDropdown: dropdown
639
+ },
640
+ methods: {
641
+ handleClick: function handleClick(e) {
642
+ this.$emit('click', e);
643
+ }
644
+ }
645
+ });
646
+ // CONCATENATED MODULE: ./components/dropdown/dropdown-button.vue?vue&type=script&lang=js&
647
+ /* harmony default export */ var dropdown_dropdown_buttonvue_type_script_lang_js_ = (dropdown_buttonvue_type_script_lang_js_);
648
+ // CONCATENATED MODULE: ./components/dropdown/dropdown-button.vue
649
+
650
+
651
+
652
+
653
+
654
+ /* normalize component */
655
+
656
+ var dropdown_button_component = Object(componentNormalizer["a" /* default */])(
657
+ dropdown_dropdown_buttonvue_type_script_lang_js_,
658
+ dropdown_buttonvue_type_template_id_2dcfc6aa_render,
659
+ dropdown_buttonvue_type_template_id_2dcfc6aa_staticRenderFns,
660
+ false,
661
+ null,
662
+ null,
663
+ null
664
+
665
+ )
666
+
667
+ /* hot reload */
668
+ if (false) { var dropdown_button_api; }
669
+ dropdown_button_component.options.__file = "components/dropdown/dropdown-button.vue"
670
+ /* harmony default export */ var dropdown_button = (dropdown_button_component.exports);
671
+ // CONCATENATED MODULE: ./components/dropdown/index.js
672
+
673
+
674
+
675
+
676
+ dropdown.Button = dropdown_button;
677
+ /* istanbul ignore next */
678
+ dropdown.install = function (Vue) {
679
+ Vue.component(dropdown.name, dropdown);
680
+ Vue.component(dropdown_button.name, dropdown_button);
681
+ };
682
+ /* harmony default export */ var components_dropdown = __webpack_exports__["default"] = (dropdown);
683
+
684
+ /***/ })
685
+
686
+ /******/ });
687
+ });