cy-element-ui 1.0.48 → 1.0.49

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 (98) hide show
  1. package/lib/alert.js +108 -108
  2. package/lib/aside.js +77 -77
  3. package/lib/autocomplete.js +5199 -360
  4. package/lib/avatar.js +4 -4
  5. package/lib/backtop.js +192 -101
  6. package/lib/badge.js +108 -108
  7. package/lib/breadcrumb-item.js +108 -108
  8. package/lib/breadcrumb.js +94 -94
  9. package/lib/button-group.js +4 -4
  10. package/lib/button.js +4 -4
  11. package/lib/calendar.js +1734 -137
  12. package/lib/card.js +96 -96
  13. package/lib/carousel-item.js +452 -108
  14. package/lib/carousel.js +1256 -105
  15. package/lib/cascader-panel.js +3524 -191
  16. package/lib/cascader.js +8077 -717
  17. package/lib/checkbox-button.js +151 -119
  18. package/lib/checkbox-group.js +47 -15
  19. package/lib/checkbox.js +47 -15
  20. package/lib/col.js +2 -2
  21. package/lib/collapse-item.js +815 -110
  22. package/lib/collapse.js +108 -108
  23. package/lib/color-picker.js +4705 -828
  24. package/lib/container.js +88 -88
  25. package/lib/date-picker.js +10735 -4739
  26. package/lib/descriptions-item.js +2 -2
  27. package/lib/descriptions.js +63 -8
  28. package/lib/dialog.js +1200 -22
  29. package/lib/divider.js +104 -104
  30. package/lib/drawer.js +875 -105
  31. package/lib/dropdown-item.js +128 -96
  32. package/lib/dropdown-menu.js +2301 -99
  33. package/lib/dropdown.js +990 -54
  34. package/lib/element-ui.common.js +31058 -13663
  35. package/lib/empty.js +793 -99
  36. package/lib/fileUpload.js +2542 -26
  37. package/lib/footer.js +77 -77
  38. package/lib/form-item.js +3305 -202
  39. package/lib/form.js +129 -115
  40. package/lib/header.js +77 -77
  41. package/lib/icon.js +67 -67
  42. package/lib/image.js +1662 -146
  43. package/lib/index.js +1 -1
  44. package/lib/infinite-scroll.js +435 -26
  45. package/lib/input-number.js +1421 -32
  46. package/lib/input.js +509 -37
  47. package/lib/link.js +4 -4
  48. package/lib/loading.js +886 -149
  49. package/lib/main.js +64 -64
  50. package/lib/menu-item-group.js +103 -103
  51. package/lib/menu-item.js +3140 -137
  52. package/lib/menu.js +959 -268
  53. package/lib/message-box.js +2743 -188
  54. package/lib/message.js +1196 -118
  55. package/lib/notification.js +1196 -119
  56. package/lib/option-group.js +151 -119
  57. package/lib/option.js +392 -16
  58. package/lib/page-header.js +781 -87
  59. package/lib/pagination.js +7747 -646
  60. package/lib/popconfirm.js +3606 -219
  61. package/lib/popover.js +2604 -79
  62. package/lib/progress.js +4 -4
  63. package/lib/radio-button.js +151 -119
  64. package/lib/radio-group.js +151 -119
  65. package/lib/radio.js +47 -15
  66. package/lib/rate.js +756 -113
  67. package/lib/result.js +108 -108
  68. package/lib/row.js +2 -2
  69. package/lib/scrollbar.js +1813 -41
  70. package/lib/select.js +5547 -209
  71. package/lib/selectDisplayInput.js +4 -4
  72. package/lib/skeleton-item.js +108 -108
  73. package/lib/skeleton.js +108 -108
  74. package/lib/slider.js +4768 -530
  75. package/lib/spinner.js +100 -100
  76. package/lib/statistic.js +9600 -112
  77. package/lib/step.js +108 -108
  78. package/lib/steps.js +514 -99
  79. package/lib/subTitle.js +91 -91
  80. package/lib/submenu.js +2397 -76
  81. package/lib/switch.js +582 -127
  82. package/lib/tab-pane.js +108 -108
  83. package/lib/tabDialog.js +1630 -104
  84. package/lib/table-column.js +1115 -267
  85. package/lib/table.js +7067 -1253
  86. package/lib/tabs.js +1615 -113
  87. package/lib/tag.js +4 -4
  88. package/lib/time-picker.js +6481 -589
  89. package/lib/time-select.js +6334 -407
  90. package/lib/timeline-item.js +108 -108
  91. package/lib/timeline.js +4 -4
  92. package/lib/tooltip.js +2688 -44
  93. package/lib/transfer.js +2238 -146
  94. package/lib/tree.js +1563 -148
  95. package/lib/treeSelect.js +3421 -106
  96. package/lib/upload.js +1198 -31
  97. package/package.json +1 -1
  98. package/src/index.js +1 -1
@@ -82,124 +82,464 @@ module.exports =
82
82
  /******/
83
83
  /******/
84
84
  /******/ // Load entry module and return exports
85
- /******/ return __webpack_require__(__webpack_require__.s = 87);
85
+ /******/ return __webpack_require__(__webpack_require__.s = 159);
86
86
  /******/ })
87
87
  /************************************************************************/
88
88
  /******/ ({
89
89
 
90
90
  /***/ 0:
91
+ /***/ (function(module, exports) {
92
+
93
+ module.exports = require("vue");
94
+
95
+ /***/ }),
96
+
97
+ /***/ 1:
91
98
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
92
99
 
93
100
  "use strict";
94
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
95
- /* globals __VUE_SSR_CONTEXT__ */
101
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "g", function() { return on; });
102
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "f", function() { return off; });
103
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "h", function() { return once; });
104
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "d", function() { return hasClass; });
105
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return addClass; });
106
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "i", function() { return removeClass; });
107
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "c", function() { return getStyle; });
108
+ /* unused harmony export setStyle */
109
+ /* unused harmony export isScroll */
110
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return getScrollContainer; });
111
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "e", function() { return isInContainer; });
112
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(0);
113
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_0__);
114
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
96
115
 
97
- // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
98
- // This module is a runtime utility for cleaner component module output and will
99
- // be included in the final webpack user bundle.
116
+ /* istanbul ignore next */
100
117
 
101
- function normalizeComponent(
102
- scriptExports,
103
- render,
104
- staticRenderFns,
105
- functionalTemplate,
106
- injectStyles,
107
- scopeId,
108
- moduleIdentifier /* server only */,
109
- shadowMode /* vue-cli only */
110
- ) {
111
- // Vue.extend constructor export interop
112
- var options =
113
- typeof scriptExports === 'function' ? scriptExports.options : scriptExports
114
118
 
115
- // render functions
116
- if (render) {
117
- options.render = render
118
- options.staticRenderFns = staticRenderFns
119
- options._compiled = true
120
- }
121
119
 
122
- // functional template
123
- if (functionalTemplate) {
124
- options.functional = true
125
- }
120
+ var isServer = vue__WEBPACK_IMPORTED_MODULE_0___default.a.prototype.$isServer;
121
+ var SPECIAL_CHARS_REGEXP = /([\:\-\_]+(.))/g;
122
+ var MOZ_HACK_REGEXP = /^moz([A-Z])/;
123
+ var ieVersion = isServer ? 0 : Number(document.documentMode);
126
124
 
127
- // scopedId
128
- if (scopeId) {
129
- options._scopeId = 'data-v-' + scopeId
130
- }
125
+ /* istanbul ignore next */
126
+ var trim = function trim(string) {
127
+ return (string || '').replace(/^[\s\uFEFF]+|[\s\uFEFF]+$/g, '');
128
+ };
129
+ /* istanbul ignore next */
130
+ var camelCase = function camelCase(name) {
131
+ return name.replace(SPECIAL_CHARS_REGEXP, function (_, separator, letter, offset) {
132
+ return offset ? letter.toUpperCase() : letter;
133
+ }).replace(MOZ_HACK_REGEXP, 'Moz$1');
134
+ };
131
135
 
132
- var hook
133
- if (moduleIdentifier) {
134
- // server build
135
- hook = function (context) {
136
- // 2.3 injection
137
- context =
138
- context || // cached call
139
- (this.$vnode && this.$vnode.ssrContext) || // stateful
140
- (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
141
- // 2.2 with runInNewContext: true
142
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
143
- context = __VUE_SSR_CONTEXT__
144
- }
145
- // inject component styles
146
- if (injectStyles) {
147
- injectStyles.call(this, context)
148
- }
149
- // register component module identifier for async chunk inferrence
150
- if (context && context._registeredComponents) {
151
- context._registeredComponents.add(moduleIdentifier)
152
- }
153
- }
154
- // used by ssr in case component is cached and beforeCreate
155
- // never gets called
156
- options._ssrRegister = hook
157
- } else if (injectStyles) {
158
- hook = shadowMode
159
- ? function () {
160
- injectStyles.call(
161
- this,
162
- (options.functional ? this.parent : this).$root.$options.shadowRoot
163
- )
164
- }
165
- : injectStyles
166
- }
136
+ /* istanbul ignore next */
137
+ var on = function () {
138
+ if (!isServer && document.addEventListener) {
139
+ return function (element, event, handler) {
140
+ if (element && event && handler) {
141
+ element.addEventListener(event, handler, false);
142
+ }
143
+ };
144
+ } else {
145
+ return function (element, event, handler) {
146
+ if (element && event && handler) {
147
+ element.attachEvent('on' + event, handler);
148
+ }
149
+ };
150
+ }
151
+ }();
167
152
 
168
- if (hook) {
169
- if (options.functional) {
170
- // for template-only hot-reload because in that case the render fn doesn't
171
- // go through the normalizer
172
- options._injectStyles = hook
173
- // register for functional component in vue file
174
- var originalRender = options.render
175
- options.render = function renderWithStyleInjection(h, context) {
176
- hook.call(context)
177
- return originalRender(h, context)
178
- }
179
- } else {
180
- // inject component registration as beforeCreate hook
181
- var existing = options.beforeCreate
182
- options.beforeCreate = existing ? [].concat(existing, hook) : [hook]
183
- }
184
- }
153
+ /* istanbul ignore next */
154
+ var off = function () {
155
+ if (!isServer && document.removeEventListener) {
156
+ return function (element, event, handler) {
157
+ if (element && event) {
158
+ element.removeEventListener(event, handler, false);
159
+ }
160
+ };
161
+ } else {
162
+ return function (element, event, handler) {
163
+ if (element && event) {
164
+ element.detachEvent('on' + event, handler);
165
+ }
166
+ };
167
+ }
168
+ }();
185
169
 
186
- return {
187
- exports: scriptExports,
188
- options: options
189
- }
190
- }
170
+ /* istanbul ignore next */
171
+ var once = function once(el, event, fn) {
172
+ var listener = function listener() {
173
+ if (fn) {
174
+ fn.apply(this, arguments);
175
+ }
176
+ off(el, event, listener);
177
+ };
178
+ on(el, event, listener);
179
+ };
180
+
181
+ /* istanbul ignore next */
182
+ function hasClass(el, cls) {
183
+ if (!el || !cls) return false;
184
+ if (cls.indexOf(' ') !== -1) throw new Error('className should not contain space.');
185
+ if (el.classList) {
186
+ return el.classList.contains(cls);
187
+ } else {
188
+ return (' ' + el.className + ' ').indexOf(' ' + cls + ' ') > -1;
189
+ }
190
+ };
191
+
192
+ /* istanbul ignore next */
193
+ function addClass(el, cls) {
194
+ if (!el) return;
195
+ var curClass = el.className;
196
+ var classes = (cls || '').split(' ');
197
+
198
+ for (var i = 0, j = classes.length; i < j; i++) {
199
+ var clsName = classes[i];
200
+ if (!clsName) continue;
201
+
202
+ if (el.classList) {
203
+ el.classList.add(clsName);
204
+ } else if (!hasClass(el, clsName)) {
205
+ curClass += ' ' + clsName;
206
+ }
207
+ }
208
+ if (!el.classList) {
209
+ el.setAttribute('class', curClass);
210
+ }
211
+ };
212
+
213
+ /* istanbul ignore next */
214
+ function removeClass(el, cls) {
215
+ if (!el || !cls) return;
216
+ var classes = cls.split(' ');
217
+ var curClass = ' ' + el.className + ' ';
191
218
 
219
+ for (var i = 0, j = classes.length; i < j; i++) {
220
+ var clsName = classes[i];
221
+ if (!clsName) continue;
222
+
223
+ if (el.classList) {
224
+ el.classList.remove(clsName);
225
+ } else if (hasClass(el, clsName)) {
226
+ curClass = curClass.replace(' ' + clsName + ' ', ' ');
227
+ }
228
+ }
229
+ if (!el.classList) {
230
+ el.setAttribute('class', trim(curClass));
231
+ }
232
+ };
233
+
234
+ /* istanbul ignore next */
235
+ var getStyle = ieVersion < 9 ? function (element, styleName) {
236
+ if (isServer) return;
237
+ if (!element || !styleName) return null;
238
+ styleName = camelCase(styleName);
239
+ if (styleName === 'float') {
240
+ styleName = 'styleFloat';
241
+ }
242
+ try {
243
+ switch (styleName) {
244
+ case 'opacity':
245
+ try {
246
+ return element.filters.item('alpha').opacity / 100;
247
+ } catch (e) {
248
+ return 1.0;
249
+ }
250
+ default:
251
+ return element.style[styleName] || element.currentStyle ? element.currentStyle[styleName] : null;
252
+ }
253
+ } catch (e) {
254
+ return element.style[styleName];
255
+ }
256
+ } : function (element, styleName) {
257
+ if (isServer) return;
258
+ if (!element || !styleName) return null;
259
+ styleName = camelCase(styleName);
260
+ if (styleName === 'float') {
261
+ styleName = 'cssFloat';
262
+ }
263
+ try {
264
+ var computed = document.defaultView.getComputedStyle(element, '');
265
+ return element.style[styleName] || computed ? computed[styleName] : null;
266
+ } catch (e) {
267
+ return element.style[styleName];
268
+ }
269
+ };
270
+
271
+ /* istanbul ignore next */
272
+ function setStyle(element, styleName, value) {
273
+ if (!element || !styleName) return;
274
+
275
+ if ((typeof styleName === 'undefined' ? 'undefined' : _typeof(styleName)) === 'object') {
276
+ for (var prop in styleName) {
277
+ if (styleName.hasOwnProperty(prop)) {
278
+ setStyle(element, prop, styleName[prop]);
279
+ }
280
+ }
281
+ } else {
282
+ styleName = camelCase(styleName);
283
+ if (styleName === 'opacity' && ieVersion < 9) {
284
+ element.style.filter = isNaN(value) ? '' : 'alpha(opacity=' + value * 100 + ')';
285
+ } else {
286
+ element.style[styleName] = value;
287
+ }
288
+ }
289
+ };
290
+
291
+ var isScroll = function isScroll(el, vertical) {
292
+ if (isServer) return;
293
+
294
+ var determinedDirection = vertical !== null && vertical !== undefined;
295
+ var overflow = determinedDirection ? vertical ? getStyle(el, 'overflow-y') : getStyle(el, 'overflow-x') : getStyle(el, 'overflow');
296
+
297
+ return overflow.match(/(scroll|auto|overlay)/);
298
+ };
299
+
300
+ var getScrollContainer = function getScrollContainer(el, vertical) {
301
+ if (isServer) return;
302
+
303
+ var parent = el;
304
+ while (parent) {
305
+ if ([window, document, document.documentElement].includes(parent)) {
306
+ return window;
307
+ }
308
+ if (isScroll(parent, vertical)) {
309
+ return parent;
310
+ }
311
+ parent = parent.parentNode;
312
+ }
313
+
314
+ return parent;
315
+ };
316
+
317
+ var isInContainer = function isInContainer(el, container) {
318
+ if (isServer || !el || !container) return false;
319
+
320
+ var elRect = el.getBoundingClientRect();
321
+ var containerRect = void 0;
322
+
323
+ if ([window, document, document.documentElement, null, undefined].includes(container)) {
324
+ containerRect = {
325
+ top: 0,
326
+ right: window.innerWidth,
327
+ bottom: window.innerHeight,
328
+ left: 0
329
+ };
330
+ } else {
331
+ containerRect = container.getBoundingClientRect();
332
+ }
333
+
334
+ return elRect.top < containerRect.bottom && elRect.bottom > containerRect.top && elRect.right > containerRect.left && elRect.left < containerRect.right;
335
+ };
192
336
 
193
337
  /***/ }),
194
338
 
195
- /***/ 5:
196
- /***/ (function(module, exports) {
339
+ /***/ 10:
340
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
341
+
342
+ "use strict";
343
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(0);
344
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_0__);
345
+ /* harmony import */ var element_ui_src_utils_popup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(9);
346
+
347
+
348
+
349
+ var PopperJS = vue__WEBPACK_IMPORTED_MODULE_0___default.a.prototype.$isServer ? function () {} : __webpack_require__(24);
350
+ var stop = function stop(e) {
351
+ return e.stopPropagation();
352
+ };
353
+
354
+ /**
355
+ * @param {HTMLElement} [reference=$refs.reference] - The reference element used to position the popper.
356
+ * @param {HTMLElement} [popper=$refs.popper] - The HTML element used as popper, or a configuration used to generate the popper.
357
+ * @param {String} [placement=button] - Placement of the popper accepted values: top(-start, -end), right(-start, -end), bottom(-start, -end), left(-start, -end)
358
+ * @param {Number} [offset=0] - Amount of pixels the popper will be shifted (can be negative).
359
+ * @param {Boolean} [visible=false] Visibility of the popup element.
360
+ * @param {Boolean} [visible-arrow=false] Visibility of the arrow, no style.
361
+ */
362
+ /* harmony default export */ __webpack_exports__["a"] = ({
363
+ props: {
364
+ transformOrigin: {
365
+ type: [Boolean, String],
366
+ default: true
367
+ },
368
+ placement: {
369
+ type: String,
370
+ default: 'bottom'
371
+ },
372
+ boundariesPadding: {
373
+ type: Number,
374
+ default: 5
375
+ },
376
+ reference: {},
377
+ popper: {},
378
+ offset: {
379
+ default: 0
380
+ },
381
+ value: Boolean,
382
+ visibleArrow: Boolean,
383
+ arrowOffset: {
384
+ type: Number,
385
+ default: 35
386
+ },
387
+ appendToBody: {
388
+ type: Boolean,
389
+ default: true
390
+ },
391
+ popperOptions: {
392
+ type: Object,
393
+ default: function _default() {
394
+ return {
395
+ gpuAcceleration: false
396
+ };
397
+ }
398
+ }
399
+ },
400
+
401
+ data: function data() {
402
+ return {
403
+ showPopper: false,
404
+ currentPlacement: ''
405
+ };
406
+ },
407
+
408
+
409
+ watch: {
410
+ value: {
411
+ immediate: true,
412
+ handler: function handler(val) {
413
+ this.showPopper = val;
414
+ this.$emit('input', val);
415
+ }
416
+ },
417
+
418
+ showPopper: function showPopper(val) {
419
+ if (this.disabled) return;
420
+ val ? this.updatePopper() : this.destroyPopper();
421
+ this.$emit('input', val);
422
+ }
423
+ },
424
+
425
+ methods: {
426
+ createPopper: function createPopper() {
427
+ var _this = this;
428
+
429
+ if (this.$isServer) return;
430
+ this.currentPlacement = this.currentPlacement || this.placement;
431
+ if (!/^(top|bottom|left|right)(-start|-end)?$/g.test(this.currentPlacement)) {
432
+ return;
433
+ }
434
+
435
+ var options = this.popperOptions;
436
+ var popper = this.popperElm = this.popperElm || this.popper || this.$refs.popper;
437
+ var reference = this.referenceElm = this.referenceElm || this.reference || this.$refs.reference;
438
+
439
+ if (!reference && this.$slots.reference && this.$slots.reference[0]) {
440
+ reference = this.referenceElm = this.$slots.reference[0].elm;
441
+ }
442
+
443
+ if (!popper || !reference) return;
444
+ if (this.visibleArrow) this.appendArrow(popper);
445
+ if (this.appendToBody) document.body.appendChild(this.popperElm);
446
+ if (this.popperJS && this.popperJS.destroy) {
447
+ this.popperJS.destroy();
448
+ }
449
+
450
+ options.placement = this.currentPlacement;
451
+ options.offset = this.offset;
452
+ options.arrowOffset = this.arrowOffset;
453
+ this.popperJS = new PopperJS(reference, popper, options);
454
+ this.popperJS.onCreate(function (_) {
455
+ _this.$emit('created', _this);
456
+ _this.resetTransformOrigin();
457
+ _this.$nextTick(_this.updatePopper);
458
+ });
459
+ if (typeof options.onUpdate === 'function') {
460
+ this.popperJS.onUpdate(options.onUpdate);
461
+ }
462
+ this.popperJS._popper.style.zIndex = element_ui_src_utils_popup__WEBPACK_IMPORTED_MODULE_1__[/* PopupManager */ "a"].nextZIndex();
463
+ this.popperElm.addEventListener('click', stop);
464
+ },
465
+ updatePopper: function updatePopper() {
466
+ var popperJS = this.popperJS;
467
+ if (popperJS) {
468
+ popperJS.update();
469
+ if (popperJS._popper) {
470
+ popperJS._popper.style.zIndex = element_ui_src_utils_popup__WEBPACK_IMPORTED_MODULE_1__[/* PopupManager */ "a"].nextZIndex();
471
+ }
472
+ } else {
473
+ this.createPopper();
474
+ }
475
+ },
476
+ doDestroy: function doDestroy(forceDestroy) {
477
+ /* istanbul ignore if */
478
+ if (!this.popperJS || this.showPopper && !forceDestroy) return;
479
+ this.popperJS.destroy();
480
+ this.popperJS = null;
481
+ },
482
+ destroyPopper: function destroyPopper() {
483
+ if (this.popperJS) {
484
+ this.resetTransformOrigin();
485
+ }
486
+ },
487
+ resetTransformOrigin: function resetTransformOrigin() {
488
+ if (!this.transformOrigin) return;
489
+ var placementMap = {
490
+ top: 'bottom',
491
+ bottom: 'top',
492
+ left: 'right',
493
+ right: 'left'
494
+ };
495
+ var placement = this.popperJS._popper.getAttribute('x-placement').split('-')[0];
496
+ var origin = placementMap[placement];
497
+ this.popperJS._popper.style.transformOrigin = typeof this.transformOrigin === 'string' ? this.transformOrigin : ['top', 'bottom'].indexOf(placement) > -1 ? 'center ' + origin : origin + ' center';
498
+ },
499
+ appendArrow: function appendArrow(element) {
500
+ var hash = void 0;
501
+ if (this.appended) {
502
+ return;
503
+ }
504
+
505
+ this.appended = true;
506
+
507
+ for (var item in element.attributes) {
508
+ if (/^_v-/.test(element.attributes[item].name)) {
509
+ hash = element.attributes[item].name;
510
+ break;
511
+ }
512
+ }
513
+
514
+ var arrow = document.createElement('div');
515
+
516
+ if (hash) {
517
+ arrow.setAttribute(hash, '');
518
+ }
519
+ arrow.setAttribute('x-arrow', '');
520
+ arrow.className = 'popper__arrow';
521
+ element.appendChild(arrow);
522
+ }
523
+ },
524
+
525
+ beforeDestroy: function beforeDestroy() {
526
+ this.doDestroy(true);
527
+ if (this.popperElm && this.popperElm.parentNode === document.body) {
528
+ this.popperElm.removeEventListener('click', stop);
529
+ document.body.removeChild(this.popperElm);
530
+ }
531
+ },
532
+
197
533
 
198
- module.exports = require("element-ui/lib/utils/vue-popper");
534
+ // call destroy in keep-alive mode
535
+ deactivated: function deactivated() {
536
+ this.$options.beforeDestroy[0].call(this);
537
+ }
538
+ });
199
539
 
200
540
  /***/ }),
201
541
 
202
- /***/ 87:
542
+ /***/ 159:
203
543
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
204
544
 
205
545
  "use strict";
@@ -240,9 +580,8 @@ render._withStripped = true
240
580
 
241
581
  // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=f47388ae
242
582
 
243
- // EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper"
244
- var vue_popper_ = __webpack_require__(5);
245
- var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_);
583
+ // EXTERNAL MODULE: ./src/utils/vue-popper.js
584
+ var vue_popper = __webpack_require__(10);
246
585
 
247
586
  // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js
248
587
 
@@ -253,7 +592,7 @@ var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_);
253
592
 
254
593
  componentName: 'ElDropdownMenu',
255
594
 
256
- mixins: [vue_popper_default.a],
595
+ mixins: [vue_popper["a" /* default */]],
257
596
 
258
597
  props: {
259
598
  visibleArrow: {
@@ -306,7 +645,7 @@ var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_);
306
645
  // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js
307
646
  /* harmony default export */ var src_dropdown_menuvue_type_script_lang_js = (dropdown_menuvue_type_script_lang_js);
308
647
  // EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
309
- var componentNormalizer = __webpack_require__(0);
648
+ var componentNormalizer = __webpack_require__(2);
310
649
 
311
650
  // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue
312
651
 
@@ -338,6 +677,1869 @@ dropdown_menu.install = function (Vue) {
338
677
 
339
678
  /* harmony default export */ var packages_dropdown_menu = __webpack_exports__["default"] = (dropdown_menu);
340
679
 
680
+ /***/ }),
681
+
682
+ /***/ 2:
683
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
684
+
685
+ "use strict";
686
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
687
+ /* globals __VUE_SSR_CONTEXT__ */
688
+
689
+ // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
690
+ // This module is a runtime utility for cleaner component module output and will
691
+ // be included in the final webpack user bundle.
692
+
693
+ function normalizeComponent(
694
+ scriptExports,
695
+ render,
696
+ staticRenderFns,
697
+ functionalTemplate,
698
+ injectStyles,
699
+ scopeId,
700
+ moduleIdentifier /* server only */,
701
+ shadowMode /* vue-cli only */
702
+ ) {
703
+ // Vue.extend constructor export interop
704
+ var options =
705
+ typeof scriptExports === 'function' ? scriptExports.options : scriptExports
706
+
707
+ // render functions
708
+ if (render) {
709
+ options.render = render
710
+ options.staticRenderFns = staticRenderFns
711
+ options._compiled = true
712
+ }
713
+
714
+ // functional template
715
+ if (functionalTemplate) {
716
+ options.functional = true
717
+ }
718
+
719
+ // scopedId
720
+ if (scopeId) {
721
+ options._scopeId = 'data-v-' + scopeId
722
+ }
723
+
724
+ var hook
725
+ if (moduleIdentifier) {
726
+ // server build
727
+ hook = function (context) {
728
+ // 2.3 injection
729
+ context =
730
+ context || // cached call
731
+ (this.$vnode && this.$vnode.ssrContext) || // stateful
732
+ (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
733
+ // 2.2 with runInNewContext: true
734
+ if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
735
+ context = __VUE_SSR_CONTEXT__
736
+ }
737
+ // inject component styles
738
+ if (injectStyles) {
739
+ injectStyles.call(this, context)
740
+ }
741
+ // register component module identifier for async chunk inferrence
742
+ if (context && context._registeredComponents) {
743
+ context._registeredComponents.add(moduleIdentifier)
744
+ }
745
+ }
746
+ // used by ssr in case component is cached and beforeCreate
747
+ // never gets called
748
+ options._ssrRegister = hook
749
+ } else if (injectStyles) {
750
+ hook = shadowMode
751
+ ? function () {
752
+ injectStyles.call(
753
+ this,
754
+ (options.functional ? this.parent : this).$root.$options.shadowRoot
755
+ )
756
+ }
757
+ : injectStyles
758
+ }
759
+
760
+ if (hook) {
761
+ if (options.functional) {
762
+ // for template-only hot-reload because in that case the render fn doesn't
763
+ // go through the normalizer
764
+ options._injectStyles = hook
765
+ // register for functional component in vue file
766
+ var originalRender = options.render
767
+ options.render = function renderWithStyleInjection(h, context) {
768
+ hook.call(context)
769
+ return originalRender(h, context)
770
+ }
771
+ } else {
772
+ // inject component registration as beforeCreate hook
773
+ var existing = options.beforeCreate
774
+ options.beforeCreate = existing ? [].concat(existing, hook) : [hook]
775
+ }
776
+ }
777
+
778
+ return {
779
+ exports: scriptExports,
780
+ options: options
781
+ }
782
+ }
783
+
784
+
785
+ /***/ }),
786
+
787
+ /***/ 24:
788
+ /***/ (function(module, exports, __webpack_require__) {
789
+
790
+ var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
791
+
792
+ /**
793
+ * @fileOverview Kickass library to create and place poppers near their reference elements.
794
+ * @version {{version}}
795
+ * @license
796
+ * Copyright (c) 2016 Federico Zivolo and contributors
797
+ *
798
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
799
+ * of this software and associated documentation files (the "Software"), to deal
800
+ * in the Software without restriction, including without limitation the rights
801
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
802
+ * copies of the Software, and to permit persons to whom the Software is
803
+ * furnished to do so, subject to the following conditions:
804
+ *
805
+ * The above copyright notice and this permission notice shall be included in all
806
+ * copies or substantial portions of the Software.
807
+ *
808
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
809
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
810
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
811
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
812
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
813
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
814
+ * SOFTWARE.
815
+ */
816
+
817
+ //
818
+ // Cross module loader
819
+ // Supported: Node, AMD, Browser globals
820
+ //
821
+ ;(function (root, factory) {
822
+ if (true) {
823
+ // AMD. Register as an anonymous module.
824
+ !(__WEBPACK_AMD_DEFINE_FACTORY__ = (factory),
825
+ __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?
826
+ (__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :
827
+ __WEBPACK_AMD_DEFINE_FACTORY__),
828
+ __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
829
+ } else {}
830
+ })(this, function () {
831
+
832
+ 'use strict';
833
+
834
+ var root = window;
835
+
836
+ // default options
837
+ var DEFAULTS = {
838
+ // placement of the popper
839
+ placement: 'bottom',
840
+
841
+ gpuAcceleration: true,
842
+
843
+ // shift popper from its origin by the given amount of pixels (can be negative)
844
+ offset: 0,
845
+
846
+ // the element which will act as boundary of the popper
847
+ boundariesElement: 'viewport',
848
+
849
+ // amount of pixel used to define a minimum distance between the boundaries and the popper
850
+ boundariesPadding: 5,
851
+
852
+ // popper will try to prevent overflow following this order,
853
+ // by default, then, it could overflow on the left and on top of the boundariesElement
854
+ preventOverflowOrder: ['left', 'right', 'top', 'bottom'],
855
+
856
+ // the behavior used by flip to change the placement of the popper
857
+ flipBehavior: 'flip',
858
+
859
+ arrowElement: '[x-arrow]',
860
+
861
+ arrowOffset: 0,
862
+
863
+ // list of functions used to modify the offsets before they are applied to the popper
864
+ modifiers: ['shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle'],
865
+
866
+ modifiersIgnored: [],
867
+
868
+ forceAbsolute: false
869
+ };
870
+
871
+ /**
872
+ * Create a new Popper.js instance
873
+ * @constructor Popper
874
+ * @param {HTMLElement} reference - The reference element used to position the popper
875
+ * @param {HTMLElement|Object} popper
876
+ * The HTML element used as popper, or a configuration used to generate the popper.
877
+ * @param {String} [popper.tagName='div'] The tag name of the generated popper.
878
+ * @param {Array} [popper.classNames=['popper']] Array of classes to apply to the generated popper.
879
+ * @param {Array} [popper.attributes] Array of attributes to apply, specify `attr:value` to assign a value to it.
880
+ * @param {HTMLElement|String} [popper.parent=window.document.body] The parent element, given as HTMLElement or as query string.
881
+ * @param {String} [popper.content=''] The content of the popper, it can be text, html, or node; if it is not text, set `contentType` to `html` or `node`.
882
+ * @param {String} [popper.contentType='text'] If `html`, the `content` will be parsed as HTML. If `node`, it will be appended as-is.
883
+ * @param {String} [popper.arrowTagName='div'] Same as `popper.tagName` but for the arrow element.
884
+ * @param {Array} [popper.arrowClassNames='popper__arrow'] Same as `popper.classNames` but for the arrow element.
885
+ * @param {String} [popper.arrowAttributes=['x-arrow']] Same as `popper.attributes` but for the arrow element.
886
+ * @param {Object} options
887
+ * @param {String} [options.placement=bottom]
888
+ * Placement of the popper accepted values: `top(-start, -end), right(-start, -end), bottom(-start, -right),
889
+ * left(-start, -end)`
890
+ *
891
+ * @param {HTMLElement|String} [options.arrowElement='[x-arrow]']
892
+ * The DOM Node used as arrow for the popper, or a CSS selector used to get the DOM node. It must be child of
893
+ * its parent Popper. Popper.js will apply to the given element the style required to align the arrow with its
894
+ * reference element.
895
+ * By default, it will look for a child node of the popper with the `x-arrow` attribute.
896
+ *
897
+ * @param {Boolean} [options.gpuAcceleration=true]
898
+ * When this property is set to true, the popper position will be applied using CSS3 translate3d, allowing the
899
+ * browser to use the GPU to accelerate the rendering.
900
+ * If set to false, the popper will be placed using `top` and `left` properties, not using the GPU.
901
+ *
902
+ * @param {Number} [options.offset=0]
903
+ * Amount of pixels the popper will be shifted (can be negative).
904
+ *
905
+ * @param {String|Element} [options.boundariesElement='viewport']
906
+ * The element which will define the boundaries of the popper position, the popper will never be placed outside
907
+ * of the defined boundaries (except if `keepTogether` is enabled)
908
+ *
909
+ * @param {Number} [options.boundariesPadding=5]
910
+ * Additional padding for the boundaries
911
+ *
912
+ * @param {Array} [options.preventOverflowOrder=['left', 'right', 'top', 'bottom']]
913
+ * Order used when Popper.js tries to avoid overflows from the boundaries, they will be checked in order,
914
+ * this means that the last ones will never overflow
915
+ *
916
+ * @param {String|Array} [options.flipBehavior='flip']
917
+ * The behavior used by the `flip` modifier to change the placement of the popper when the latter is trying to
918
+ * overlap its reference element. Defining `flip` as value, the placement will be flipped on
919
+ * its axis (`right - left`, `top - bottom`).
920
+ * You can even pass an array of placements (eg: `['right', 'left', 'top']` ) to manually specify
921
+ * how alter the placement when a flip is needed. (eg. in the above example, it would first flip from right to left,
922
+ * then, if even in its new placement, the popper is overlapping its reference element, it will be moved to top)
923
+ *
924
+ * @param {Array} [options.modifiers=[ 'shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle']]
925
+ * List of functions used to modify the data before they are applied to the popper, add your custom functions
926
+ * to this array to edit the offsets and placement.
927
+ * The function should reflect the @params and @returns of preventOverflow
928
+ *
929
+ * @param {Array} [options.modifiersIgnored=[]]
930
+ * Put here any built-in modifier name you want to exclude from the modifiers list
931
+ * The function should reflect the @params and @returns of preventOverflow
932
+ *
933
+ * @param {Boolean} [options.removeOnDestroy=false]
934
+ * Set to true if you want to automatically remove the popper when you call the `destroy` method.
935
+ */
936
+ function Popper(reference, popper, options) {
937
+ this._reference = reference.jquery ? reference[0] : reference;
938
+ this.state = {};
939
+
940
+ // if the popper variable is a configuration object, parse it to generate an HTMLElement
941
+ // generate a default popper if is not defined
942
+ var isNotDefined = typeof popper === 'undefined' || popper === null;
943
+ var isConfig = popper && Object.prototype.toString.call(popper) === '[object Object]';
944
+ if (isNotDefined || isConfig) {
945
+ this._popper = this.parse(isConfig ? popper : {});
946
+ }
947
+ // otherwise, use the given HTMLElement as popper
948
+ else {
949
+ this._popper = popper.jquery ? popper[0] : popper;
950
+ }
951
+
952
+ // with {} we create a new object with the options inside it
953
+ this._options = Object.assign({}, DEFAULTS, options);
954
+
955
+ // refactoring modifiers' list
956
+ this._options.modifiers = this._options.modifiers.map(function (modifier) {
957
+ // remove ignored modifiers
958
+ if (this._options.modifiersIgnored.indexOf(modifier) !== -1) return;
959
+
960
+ // set the x-placement attribute before everything else because it could be used to add margins to the popper
961
+ // margins needs to be calculated to get the correct popper offsets
962
+ if (modifier === 'applyStyle') {
963
+ this._popper.setAttribute('x-placement', this._options.placement);
964
+ }
965
+
966
+ // return predefined modifier identified by string or keep the custom one
967
+ return this.modifiers[modifier] || modifier;
968
+ }.bind(this));
969
+
970
+ // make sure to apply the popper position before any computation
971
+ this.state.position = this._getPosition(this._popper, this._reference);
972
+ setStyle(this._popper, { position: this.state.position, top: 0 });
973
+
974
+ // fire the first update to position the popper in the right place
975
+ this.update();
976
+
977
+ // setup event listeners, they will take care of update the position in specific situations
978
+ this._setupEventListeners();
979
+ return this;
980
+ }
981
+
982
+ //
983
+ // Methods
984
+ //
985
+ /**
986
+ * Destroy the popper
987
+ * @method
988
+ * @memberof Popper
989
+ */
990
+ Popper.prototype.destroy = function () {
991
+ this._popper.removeAttribute('x-placement');
992
+ this._popper.style.left = '';
993
+ this._popper.style.position = '';
994
+ this._popper.style.top = '';
995
+ this._popper.style[getSupportedPropertyName('transform')] = '';
996
+ this._removeEventListeners();
997
+
998
+ // remove the popper if user explicity asked for the deletion on destroy
999
+ if (this._options.removeOnDestroy) {
1000
+ this._popper.remove();
1001
+ }
1002
+ return this;
1003
+ };
1004
+
1005
+ /**
1006
+ * Updates the position of the popper, computing the new offsets and applying the new style
1007
+ * @method
1008
+ * @memberof Popper
1009
+ */
1010
+ Popper.prototype.update = function () {
1011
+ var data = { instance: this, styles: {} };
1012
+
1013
+ // store placement inside the data object, modifiers will be able to edit `placement` if needed
1014
+ // and refer to _originalPlacement to know the original value
1015
+ data.placement = this._options.placement;
1016
+ data._originalPlacement = this._options.placement;
1017
+
1018
+ // compute the popper and reference offsets and put them inside data.offsets
1019
+ data.offsets = this._getOffsets(this._popper, this._reference, data.placement);
1020
+
1021
+ // get boundaries
1022
+ data.boundaries = this._getBoundaries(data, this._options.boundariesPadding, this._options.boundariesElement);
1023
+
1024
+ data = this.runModifiers(data, this._options.modifiers);
1025
+
1026
+ if (typeof this.state.updateCallback === 'function') {
1027
+ this.state.updateCallback(data);
1028
+ }
1029
+ };
1030
+
1031
+ /**
1032
+ * If a function is passed, it will be executed after the initialization of popper with as first argument the Popper instance.
1033
+ * @method
1034
+ * @memberof Popper
1035
+ * @param {Function} callback
1036
+ */
1037
+ Popper.prototype.onCreate = function (callback) {
1038
+ // the createCallbacks return as first argument the popper instance
1039
+ callback(this);
1040
+ return this;
1041
+ };
1042
+
1043
+ /**
1044
+ * If a function is passed, it will be executed after each update of popper with as first argument the set of coordinates and informations
1045
+ * used to style popper and its arrow.
1046
+ * NOTE: it doesn't get fired on the first call of the `Popper.update()` method inside the `Popper` constructor!
1047
+ * @method
1048
+ * @memberof Popper
1049
+ * @param {Function} callback
1050
+ */
1051
+ Popper.prototype.onUpdate = function (callback) {
1052
+ this.state.updateCallback = callback;
1053
+ return this;
1054
+ };
1055
+
1056
+ /**
1057
+ * Helper used to generate poppers from a configuration file
1058
+ * @method
1059
+ * @memberof Popper
1060
+ * @param config {Object} configuration
1061
+ * @returns {HTMLElement} popper
1062
+ */
1063
+ Popper.prototype.parse = function (config) {
1064
+ var defaultConfig = {
1065
+ tagName: 'div',
1066
+ classNames: ['popper'],
1067
+ attributes: [],
1068
+ parent: root.document.body,
1069
+ content: '',
1070
+ contentType: 'text',
1071
+ arrowTagName: 'div',
1072
+ arrowClassNames: ['popper__arrow'],
1073
+ arrowAttributes: ['x-arrow']
1074
+ };
1075
+ config = Object.assign({}, defaultConfig, config);
1076
+
1077
+ var d = root.document;
1078
+
1079
+ var popper = d.createElement(config.tagName);
1080
+ addClassNames(popper, config.classNames);
1081
+ addAttributes(popper, config.attributes);
1082
+ if (config.contentType === 'node') {
1083
+ popper.appendChild(config.content.jquery ? config.content[0] : config.content);
1084
+ } else if (config.contentType === 'html') {
1085
+ popper.innerHTML = config.content;
1086
+ } else {
1087
+ popper.textContent = config.content;
1088
+ }
1089
+
1090
+ if (config.arrowTagName) {
1091
+ var arrow = d.createElement(config.arrowTagName);
1092
+ addClassNames(arrow, config.arrowClassNames);
1093
+ addAttributes(arrow, config.arrowAttributes);
1094
+ popper.appendChild(arrow);
1095
+ }
1096
+
1097
+ var parent = config.parent.jquery ? config.parent[0] : config.parent;
1098
+
1099
+ // if the given parent is a string, use it to match an element
1100
+ // if more than one element is matched, the first one will be used as parent
1101
+ // if no elements are matched, the script will throw an error
1102
+ if (typeof parent === 'string') {
1103
+ parent = d.querySelectorAll(config.parent);
1104
+ if (parent.length > 1) {
1105
+ console.warn('WARNING: the given `parent` query(' + config.parent + ') matched more than one element, the first one will be used');
1106
+ }
1107
+ if (parent.length === 0) {
1108
+ throw 'ERROR: the given `parent` doesn\'t exists!';
1109
+ }
1110
+ parent = parent[0];
1111
+ }
1112
+ // if the given parent is a DOM nodes list or an array of nodes with more than one element,
1113
+ // the first one will be used as parent
1114
+ if (parent.length > 1 && parent instanceof Element === false) {
1115
+ console.warn('WARNING: you have passed as parent a list of elements, the first one will be used');
1116
+ parent = parent[0];
1117
+ }
1118
+
1119
+ // append the generated popper to its parent
1120
+ parent.appendChild(popper);
1121
+
1122
+ return popper;
1123
+
1124
+ /**
1125
+ * Adds class names to the given element
1126
+ * @function
1127
+ * @ignore
1128
+ * @param {HTMLElement} target
1129
+ * @param {Array} classes
1130
+ */
1131
+ function addClassNames(element, classNames) {
1132
+ classNames.forEach(function (className) {
1133
+ element.classList.add(className);
1134
+ });
1135
+ }
1136
+
1137
+ /**
1138
+ * Adds attributes to the given element
1139
+ * @function
1140
+ * @ignore
1141
+ * @param {HTMLElement} target
1142
+ * @param {Array} attributes
1143
+ * @example
1144
+ * addAttributes(element, [ 'data-info:foobar' ]);
1145
+ */
1146
+ function addAttributes(element, attributes) {
1147
+ attributes.forEach(function (attribute) {
1148
+ element.setAttribute(attribute.split(':')[0], attribute.split(':')[1] || '');
1149
+ });
1150
+ }
1151
+ };
1152
+
1153
+ /**
1154
+ * Helper used to get the position which will be applied to the popper
1155
+ * @method
1156
+ * @memberof Popper
1157
+ * @param config {HTMLElement} popper element
1158
+ * @param reference {HTMLElement} reference element
1159
+ * @returns {String} position
1160
+ */
1161
+ Popper.prototype._getPosition = function (popper, reference) {
1162
+ var container = getOffsetParent(reference);
1163
+
1164
+ if (this._options.forceAbsolute) {
1165
+ return 'absolute';
1166
+ }
1167
+
1168
+ // Decide if the popper will be fixed
1169
+ // If the reference element is inside a fixed context, the popper will be fixed as well to allow them to scroll together
1170
+ var isParentFixed = isFixed(reference, container);
1171
+ return isParentFixed ? 'fixed' : 'absolute';
1172
+ };
1173
+
1174
+ /**
1175
+ * Get offsets to the popper
1176
+ * @method
1177
+ * @memberof Popper
1178
+ * @access private
1179
+ * @param {Element} popper - the popper element
1180
+ * @param {Element} reference - the reference element (the popper will be relative to this)
1181
+ * @returns {Object} An object containing the offsets which will be applied to the popper
1182
+ */
1183
+ Popper.prototype._getOffsets = function (popper, reference, placement) {
1184
+ placement = placement.split('-')[0];
1185
+ var popperOffsets = {};
1186
+
1187
+ popperOffsets.position = this.state.position;
1188
+ var isParentFixed = popperOffsets.position === 'fixed';
1189
+
1190
+ //
1191
+ // Get reference element position
1192
+ //
1193
+ var referenceOffsets = getOffsetRectRelativeToCustomParent(reference, getOffsetParent(popper), isParentFixed);
1194
+
1195
+ //
1196
+ // Get popper sizes
1197
+ //
1198
+ var popperRect = getOuterSizes(popper);
1199
+
1200
+ //
1201
+ // Compute offsets of popper
1202
+ //
1203
+
1204
+ // depending by the popper placement we have to compute its offsets slightly differently
1205
+ if (['right', 'left'].indexOf(placement) !== -1) {
1206
+ popperOffsets.top = referenceOffsets.top + referenceOffsets.height / 2 - popperRect.height / 2;
1207
+ if (placement === 'left') {
1208
+ popperOffsets.left = referenceOffsets.left - popperRect.width;
1209
+ } else {
1210
+ popperOffsets.left = referenceOffsets.right;
1211
+ }
1212
+ } else {
1213
+ popperOffsets.left = referenceOffsets.left + referenceOffsets.width / 2 - popperRect.width / 2;
1214
+ if (placement === 'top') {
1215
+ popperOffsets.top = referenceOffsets.top - popperRect.height;
1216
+ } else {
1217
+ popperOffsets.top = referenceOffsets.bottom;
1218
+ }
1219
+ }
1220
+
1221
+ // Add width and height to our offsets object
1222
+ popperOffsets.width = popperRect.width;
1223
+ popperOffsets.height = popperRect.height;
1224
+
1225
+ return {
1226
+ popper: popperOffsets,
1227
+ reference: referenceOffsets
1228
+ };
1229
+ };
1230
+
1231
+ /**
1232
+ * Setup needed event listeners used to update the popper position
1233
+ * @method
1234
+ * @memberof Popper
1235
+ * @access private
1236
+ */
1237
+ Popper.prototype._setupEventListeners = function () {
1238
+ // NOTE: 1 DOM access here
1239
+ this.state.updateBound = this.update.bind(this);
1240
+ root.addEventListener('resize', this.state.updateBound);
1241
+ // if the boundariesElement is window we don't need to listen for the scroll event
1242
+ if (this._options.boundariesElement !== 'window') {
1243
+ var target = getScrollParent(this._reference);
1244
+ // here it could be both `body` or `documentElement` thanks to Firefox, we then check both
1245
+ if (target === root.document.body || target === root.document.documentElement) {
1246
+ target = root;
1247
+ }
1248
+ target.addEventListener('scroll', this.state.updateBound);
1249
+ this.state.scrollTarget = target;
1250
+ }
1251
+ };
1252
+
1253
+ /**
1254
+ * Remove event listeners used to update the popper position
1255
+ * @method
1256
+ * @memberof Popper
1257
+ * @access private
1258
+ */
1259
+ Popper.prototype._removeEventListeners = function () {
1260
+ // NOTE: 1 DOM access here
1261
+ root.removeEventListener('resize', this.state.updateBound);
1262
+ if (this._options.boundariesElement !== 'window' && this.state.scrollTarget) {
1263
+ this.state.scrollTarget.removeEventListener('scroll', this.state.updateBound);
1264
+ this.state.scrollTarget = null;
1265
+ }
1266
+ this.state.updateBound = null;
1267
+ };
1268
+
1269
+ /**
1270
+ * Computed the boundaries limits and return them
1271
+ * @method
1272
+ * @memberof Popper
1273
+ * @access private
1274
+ * @param {Object} data - Object containing the property "offsets" generated by `_getOffsets`
1275
+ * @param {Number} padding - Boundaries padding
1276
+ * @param {Element} boundariesElement - Element used to define the boundaries
1277
+ * @returns {Object} Coordinates of the boundaries
1278
+ */
1279
+ Popper.prototype._getBoundaries = function (data, padding, boundariesElement) {
1280
+ // NOTE: 1 DOM access here
1281
+ var boundaries = {};
1282
+ var width, height;
1283
+ if (boundariesElement === 'window') {
1284
+ var body = root.document.body,
1285
+ html = root.document.documentElement;
1286
+
1287
+ height = Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight);
1288
+ width = Math.max(body.scrollWidth, body.offsetWidth, html.clientWidth, html.scrollWidth, html.offsetWidth);
1289
+
1290
+ boundaries = {
1291
+ top: 0,
1292
+ right: width,
1293
+ bottom: height,
1294
+ left: 0
1295
+ };
1296
+ } else if (boundariesElement === 'viewport') {
1297
+ var offsetParent = getOffsetParent(this._popper);
1298
+ var scrollParent = getScrollParent(this._popper);
1299
+ var offsetParentRect = getOffsetRect(offsetParent);
1300
+
1301
+ // Thanks the fucking native API, `document.body.scrollTop` & `document.documentElement.scrollTop`
1302
+ var getScrollTopValue = function getScrollTopValue(element) {
1303
+ return element == document.body ? Math.max(document.documentElement.scrollTop, document.body.scrollTop) : element.scrollTop;
1304
+ };
1305
+ var getScrollLeftValue = function getScrollLeftValue(element) {
1306
+ return element == document.body ? Math.max(document.documentElement.scrollLeft, document.body.scrollLeft) : element.scrollLeft;
1307
+ };
1308
+
1309
+ // if the popper is fixed we don't have to substract scrolling from the boundaries
1310
+ var scrollTop = data.offsets.popper.position === 'fixed' ? 0 : getScrollTopValue(scrollParent);
1311
+ var scrollLeft = data.offsets.popper.position === 'fixed' ? 0 : getScrollLeftValue(scrollParent);
1312
+
1313
+ boundaries = {
1314
+ top: 0 - (offsetParentRect.top - scrollTop),
1315
+ right: root.document.documentElement.clientWidth - (offsetParentRect.left - scrollLeft),
1316
+ bottom: root.document.documentElement.clientHeight - (offsetParentRect.top - scrollTop),
1317
+ left: 0 - (offsetParentRect.left - scrollLeft)
1318
+ };
1319
+ } else {
1320
+ if (getOffsetParent(this._popper) === boundariesElement) {
1321
+ boundaries = {
1322
+ top: 0,
1323
+ left: 0,
1324
+ right: boundariesElement.clientWidth,
1325
+ bottom: boundariesElement.clientHeight
1326
+ };
1327
+ } else {
1328
+ boundaries = getOffsetRect(boundariesElement);
1329
+ }
1330
+ }
1331
+ boundaries.left += padding;
1332
+ boundaries.right -= padding;
1333
+ boundaries.top = boundaries.top + padding;
1334
+ boundaries.bottom = boundaries.bottom - padding;
1335
+ return boundaries;
1336
+ };
1337
+
1338
+ /**
1339
+ * Loop trough the list of modifiers and run them in order, each of them will then edit the data object
1340
+ * @method
1341
+ * @memberof Popper
1342
+ * @access public
1343
+ * @param {Object} data
1344
+ * @param {Array} modifiers
1345
+ * @param {Function} ends
1346
+ */
1347
+ Popper.prototype.runModifiers = function (data, modifiers, ends) {
1348
+ var modifiersToRun = modifiers.slice();
1349
+ if (ends !== undefined) {
1350
+ modifiersToRun = this._options.modifiers.slice(0, getArrayKeyIndex(this._options.modifiers, ends));
1351
+ }
1352
+
1353
+ modifiersToRun.forEach(function (modifier) {
1354
+ if (isFunction(modifier)) {
1355
+ data = modifier.call(this, data);
1356
+ }
1357
+ }.bind(this));
1358
+
1359
+ return data;
1360
+ };
1361
+
1362
+ /**
1363
+ * Helper used to know if the given modifier depends from another one.
1364
+ * @method
1365
+ * @memberof Popper
1366
+ * @param {String} requesting - name of requesting modifier
1367
+ * @param {String} requested - name of requested modifier
1368
+ * @returns {Boolean}
1369
+ */
1370
+ Popper.prototype.isModifierRequired = function (requesting, requested) {
1371
+ var index = getArrayKeyIndex(this._options.modifiers, requesting);
1372
+ return !!this._options.modifiers.slice(0, index).filter(function (modifier) {
1373
+ return modifier === requested;
1374
+ }).length;
1375
+ };
1376
+
1377
+ //
1378
+ // Modifiers
1379
+ //
1380
+
1381
+ /**
1382
+ * Modifiers list
1383
+ * @namespace Popper.modifiers
1384
+ * @memberof Popper
1385
+ * @type {Object}
1386
+ */
1387
+ Popper.prototype.modifiers = {};
1388
+
1389
+ /**
1390
+ * Apply the computed styles to the popper element
1391
+ * @method
1392
+ * @memberof Popper.modifiers
1393
+ * @argument {Object} data - The data object generated by `update` method
1394
+ * @returns {Object} The same data object
1395
+ */
1396
+ Popper.prototype.modifiers.applyStyle = function (data) {
1397
+ // apply the final offsets to the popper
1398
+ // NOTE: 1 DOM access here
1399
+ var styles = {
1400
+ position: data.offsets.popper.position
1401
+ };
1402
+
1403
+ // round top and left to avoid blurry text
1404
+ var left = Math.round(data.offsets.popper.left);
1405
+ var top = Math.round(data.offsets.popper.top);
1406
+
1407
+ // if gpuAcceleration is set to true and transform is supported, we use `translate3d` to apply the position to the popper
1408
+ // we automatically use the supported prefixed version if needed
1409
+ var prefixedProperty;
1410
+ if (this._options.gpuAcceleration && (prefixedProperty = getSupportedPropertyName('transform'))) {
1411
+ styles[prefixedProperty] = 'translate3d(' + left + 'px, ' + top + 'px, 0)';
1412
+ styles.top = 0;
1413
+ styles.left = 0;
1414
+ }
1415
+ // othwerise, we use the standard `left` and `top` properties
1416
+ else {
1417
+ styles.left = left;
1418
+ styles.top = top;
1419
+ }
1420
+
1421
+ // any property present in `data.styles` will be applied to the popper,
1422
+ // in this way we can make the 3rd party modifiers add custom styles to it
1423
+ // Be aware, modifiers could override the properties defined in the previous
1424
+ // lines of this modifier!
1425
+ Object.assign(styles, data.styles);
1426
+
1427
+ setStyle(this._popper, styles);
1428
+
1429
+ // set an attribute which will be useful to style the tooltip (use it to properly position its arrow)
1430
+ // NOTE: 1 DOM access here
1431
+ this._popper.setAttribute('x-placement', data.placement);
1432
+
1433
+ // if the arrow modifier is required and the arrow style has been computed, apply the arrow style
1434
+ if (this.isModifierRequired(this.modifiers.applyStyle, this.modifiers.arrow) && data.offsets.arrow) {
1435
+ setStyle(data.arrowElement, data.offsets.arrow);
1436
+ }
1437
+
1438
+ return data;
1439
+ };
1440
+
1441
+ /**
1442
+ * Modifier used to shift the popper on the start or end of its reference element side
1443
+ * @method
1444
+ * @memberof Popper.modifiers
1445
+ * @argument {Object} data - The data object generated by `update` method
1446
+ * @returns {Object} The data object, properly modified
1447
+ */
1448
+ Popper.prototype.modifiers.shift = function (data) {
1449
+ var placement = data.placement;
1450
+ var basePlacement = placement.split('-')[0];
1451
+ var shiftVariation = placement.split('-')[1];
1452
+
1453
+ // if shift shiftVariation is specified, run the modifier
1454
+ if (shiftVariation) {
1455
+ var reference = data.offsets.reference;
1456
+ var popper = getPopperClientRect(data.offsets.popper);
1457
+
1458
+ var shiftOffsets = {
1459
+ y: {
1460
+ start: { top: reference.top },
1461
+ end: { top: reference.top + reference.height - popper.height }
1462
+ },
1463
+ x: {
1464
+ start: { left: reference.left },
1465
+ end: { left: reference.left + reference.width - popper.width }
1466
+ }
1467
+ };
1468
+
1469
+ var axis = ['bottom', 'top'].indexOf(basePlacement) !== -1 ? 'x' : 'y';
1470
+
1471
+ data.offsets.popper = Object.assign(popper, shiftOffsets[axis][shiftVariation]);
1472
+ }
1473
+
1474
+ return data;
1475
+ };
1476
+
1477
+ /**
1478
+ * Modifier used to make sure the popper does not overflows from it's boundaries
1479
+ * @method
1480
+ * @memberof Popper.modifiers
1481
+ * @argument {Object} data - The data object generated by `update` method
1482
+ * @returns {Object} The data object, properly modified
1483
+ */
1484
+ Popper.prototype.modifiers.preventOverflow = function (data) {
1485
+ var order = this._options.preventOverflowOrder;
1486
+ var popper = getPopperClientRect(data.offsets.popper);
1487
+
1488
+ var check = {
1489
+ left: function left() {
1490
+ var left = popper.left;
1491
+ if (popper.left < data.boundaries.left) {
1492
+ left = Math.max(popper.left, data.boundaries.left);
1493
+ }
1494
+ return { left: left };
1495
+ },
1496
+ right: function right() {
1497
+ var left = popper.left;
1498
+ if (popper.right > data.boundaries.right) {
1499
+ left = Math.min(popper.left, data.boundaries.right - popper.width);
1500
+ }
1501
+ return { left: left };
1502
+ },
1503
+ top: function top() {
1504
+ var top = popper.top;
1505
+ if (popper.top < data.boundaries.top) {
1506
+ top = Math.max(popper.top, data.boundaries.top);
1507
+ }
1508
+ return { top: top };
1509
+ },
1510
+ bottom: function bottom() {
1511
+ var top = popper.top;
1512
+ if (popper.bottom > data.boundaries.bottom) {
1513
+ top = Math.min(popper.top, data.boundaries.bottom - popper.height);
1514
+ }
1515
+ return { top: top };
1516
+ }
1517
+ };
1518
+
1519
+ order.forEach(function (direction) {
1520
+ data.offsets.popper = Object.assign(popper, check[direction]());
1521
+ });
1522
+
1523
+ return data;
1524
+ };
1525
+
1526
+ /**
1527
+ * Modifier used to make sure the popper is always near its reference
1528
+ * @method
1529
+ * @memberof Popper.modifiers
1530
+ * @argument {Object} data - The data object generated by _update method
1531
+ * @returns {Object} The data object, properly modified
1532
+ */
1533
+ Popper.prototype.modifiers.keepTogether = function (data) {
1534
+ var popper = getPopperClientRect(data.offsets.popper);
1535
+ var reference = data.offsets.reference;
1536
+ var f = Math.floor;
1537
+
1538
+ if (popper.right < f(reference.left)) {
1539
+ data.offsets.popper.left = f(reference.left) - popper.width;
1540
+ }
1541
+ if (popper.left > f(reference.right)) {
1542
+ data.offsets.popper.left = f(reference.right);
1543
+ }
1544
+ if (popper.bottom < f(reference.top)) {
1545
+ data.offsets.popper.top = f(reference.top) - popper.height;
1546
+ }
1547
+ if (popper.top > f(reference.bottom)) {
1548
+ data.offsets.popper.top = f(reference.bottom);
1549
+ }
1550
+
1551
+ return data;
1552
+ };
1553
+
1554
+ /**
1555
+ * Modifier used to flip the placement of the popper when the latter is starting overlapping its reference element.
1556
+ * Requires the `preventOverflow` modifier before it in order to work.
1557
+ * **NOTE:** This modifier will run all its previous modifiers everytime it tries to flip the popper!
1558
+ * @method
1559
+ * @memberof Popper.modifiers
1560
+ * @argument {Object} data - The data object generated by _update method
1561
+ * @returns {Object} The data object, properly modified
1562
+ */
1563
+ Popper.prototype.modifiers.flip = function (data) {
1564
+ // check if preventOverflow is in the list of modifiers before the flip modifier.
1565
+ // otherwise flip would not work as expected.
1566
+ if (!this.isModifierRequired(this.modifiers.flip, this.modifiers.preventOverflow)) {
1567
+ console.warn('WARNING: preventOverflow modifier is required by flip modifier in order to work, be sure to include it before flip!');
1568
+ return data;
1569
+ }
1570
+
1571
+ if (data.flipped && data.placement === data._originalPlacement) {
1572
+ // seems like flip is trying to loop, probably there's not enough space on any of the flippable sides
1573
+ return data;
1574
+ }
1575
+
1576
+ var placement = data.placement.split('-')[0];
1577
+ var placementOpposite = getOppositePlacement(placement);
1578
+ var variation = data.placement.split('-')[1] || '';
1579
+
1580
+ var flipOrder = [];
1581
+ if (this._options.flipBehavior === 'flip') {
1582
+ flipOrder = [placement, placementOpposite];
1583
+ } else {
1584
+ flipOrder = this._options.flipBehavior;
1585
+ }
1586
+
1587
+ flipOrder.forEach(function (step, index) {
1588
+ if (placement !== step || flipOrder.length === index + 1) {
1589
+ return;
1590
+ }
1591
+
1592
+ placement = data.placement.split('-')[0];
1593
+ placementOpposite = getOppositePlacement(placement);
1594
+
1595
+ var popperOffsets = getPopperClientRect(data.offsets.popper);
1596
+
1597
+ // this boolean is used to distinguish right and bottom from top and left
1598
+ // they need different computations to get flipped
1599
+ var a = ['right', 'bottom'].indexOf(placement) !== -1;
1600
+
1601
+ // using Math.floor because the reference offsets may contain decimals we are not going to consider here
1602
+ if (a && Math.floor(data.offsets.reference[placement]) > Math.floor(popperOffsets[placementOpposite]) || !a && Math.floor(data.offsets.reference[placement]) < Math.floor(popperOffsets[placementOpposite])) {
1603
+ // we'll use this boolean to detect any flip loop
1604
+ data.flipped = true;
1605
+ data.placement = flipOrder[index + 1];
1606
+ if (variation) {
1607
+ data.placement += '-' + variation;
1608
+ }
1609
+ data.offsets.popper = this._getOffsets(this._popper, this._reference, data.placement).popper;
1610
+
1611
+ data = this.runModifiers(data, this._options.modifiers, this._flip);
1612
+ }
1613
+ }.bind(this));
1614
+ return data;
1615
+ };
1616
+
1617
+ /**
1618
+ * Modifier used to add an offset to the popper, useful if you more granularity positioning your popper.
1619
+ * The offsets will shift the popper on the side of its reference element.
1620
+ * @method
1621
+ * @memberof Popper.modifiers
1622
+ * @argument {Object} data - The data object generated by _update method
1623
+ * @returns {Object} The data object, properly modified
1624
+ */
1625
+ Popper.prototype.modifiers.offset = function (data) {
1626
+ var offset = this._options.offset;
1627
+ var popper = data.offsets.popper;
1628
+
1629
+ if (data.placement.indexOf('left') !== -1) {
1630
+ popper.top -= offset;
1631
+ } else if (data.placement.indexOf('right') !== -1) {
1632
+ popper.top += offset;
1633
+ } else if (data.placement.indexOf('top') !== -1) {
1634
+ popper.left -= offset;
1635
+ } else if (data.placement.indexOf('bottom') !== -1) {
1636
+ popper.left += offset;
1637
+ }
1638
+ return data;
1639
+ };
1640
+
1641
+ /**
1642
+ * Modifier used to move the arrows on the edge of the popper to make sure them are always between the popper and the reference element
1643
+ * It will use the CSS outer size of the arrow element to know how many pixels of conjuction are needed
1644
+ * @method
1645
+ * @memberof Popper.modifiers
1646
+ * @argument {Object} data - The data object generated by _update method
1647
+ * @returns {Object} The data object, properly modified
1648
+ */
1649
+ Popper.prototype.modifiers.arrow = function (data) {
1650
+ var arrow = this._options.arrowElement;
1651
+ var arrowOffset = this._options.arrowOffset;
1652
+
1653
+ // if the arrowElement is a string, suppose it's a CSS selector
1654
+ if (typeof arrow === 'string') {
1655
+ arrow = this._popper.querySelector(arrow);
1656
+ }
1657
+
1658
+ // if arrow element is not found, don't run the modifier
1659
+ if (!arrow) {
1660
+ return data;
1661
+ }
1662
+
1663
+ // the arrow element must be child of its popper
1664
+ if (!this._popper.contains(arrow)) {
1665
+ console.warn('WARNING: `arrowElement` must be child of its popper element!');
1666
+ return data;
1667
+ }
1668
+
1669
+ // arrow depends on keepTogether in order to work
1670
+ if (!this.isModifierRequired(this.modifiers.arrow, this.modifiers.keepTogether)) {
1671
+ console.warn('WARNING: keepTogether modifier is required by arrow modifier in order to work, be sure to include it before arrow!');
1672
+ return data;
1673
+ }
1674
+
1675
+ var arrowStyle = {};
1676
+ var placement = data.placement.split('-')[0];
1677
+ var popper = getPopperClientRect(data.offsets.popper);
1678
+ var reference = data.offsets.reference;
1679
+ var isVertical = ['left', 'right'].indexOf(placement) !== -1;
1680
+
1681
+ var len = isVertical ? 'height' : 'width';
1682
+ var side = isVertical ? 'top' : 'left';
1683
+ var translate = isVertical ? 'translateY' : 'translateX';
1684
+ var altSide = isVertical ? 'left' : 'top';
1685
+ var opSide = isVertical ? 'bottom' : 'right';
1686
+ var arrowSize = getOuterSizes(arrow)[len];
1687
+
1688
+ //
1689
+ // extends keepTogether behavior making sure the popper and its reference have enough pixels in conjuction
1690
+ //
1691
+
1692
+ // top/left side
1693
+ if (reference[opSide] - arrowSize < popper[side]) {
1694
+ data.offsets.popper[side] -= popper[side] - (reference[opSide] - arrowSize);
1695
+ }
1696
+ // bottom/right side
1697
+ if (reference[side] + arrowSize > popper[opSide]) {
1698
+ data.offsets.popper[side] += reference[side] + arrowSize - popper[opSide];
1699
+ }
1700
+
1701
+ // compute center of the popper
1702
+ var center = reference[side] + (arrowOffset || reference[len] / 2 - arrowSize / 2);
1703
+
1704
+ var sideValue = center - popper[side];
1705
+
1706
+ // prevent arrow from being placed not contiguously to its popper
1707
+ sideValue = Math.max(Math.min(popper[len] - arrowSize - 8, sideValue), 8);
1708
+ arrowStyle[side] = sideValue;
1709
+ arrowStyle[altSide] = ''; // make sure to remove any old style from the arrow
1710
+
1711
+ data.offsets.arrow = arrowStyle;
1712
+ data.arrowElement = arrow;
1713
+
1714
+ return data;
1715
+ };
1716
+
1717
+ //
1718
+ // Helpers
1719
+ //
1720
+
1721
+ /**
1722
+ * Get the outer sizes of the given element (offset size + margins)
1723
+ * @function
1724
+ * @ignore
1725
+ * @argument {Element} element
1726
+ * @returns {Object} object containing width and height properties
1727
+ */
1728
+ function getOuterSizes(element) {
1729
+ // NOTE: 1 DOM access here
1730
+ var _display = element.style.display,
1731
+ _visibility = element.style.visibility;
1732
+ element.style.display = 'block';element.style.visibility = 'hidden';
1733
+ var calcWidthToForceRepaint = element.offsetWidth;
1734
+
1735
+ // original method
1736
+ var styles = root.getComputedStyle(element);
1737
+ var x = parseFloat(styles.marginTop) + parseFloat(styles.marginBottom);
1738
+ var y = parseFloat(styles.marginLeft) + parseFloat(styles.marginRight);
1739
+ var result = { width: element.offsetWidth + y, height: element.offsetHeight + x };
1740
+
1741
+ // reset element styles
1742
+ element.style.display = _display;element.style.visibility = _visibility;
1743
+ return result;
1744
+ }
1745
+
1746
+ /**
1747
+ * Get the opposite placement of the given one/
1748
+ * @function
1749
+ * @ignore
1750
+ * @argument {String} placement
1751
+ * @returns {String} flipped placement
1752
+ */
1753
+ function getOppositePlacement(placement) {
1754
+ var hash = { left: 'right', right: 'left', bottom: 'top', top: 'bottom' };
1755
+ return placement.replace(/left|right|bottom|top/g, function (matched) {
1756
+ return hash[matched];
1757
+ });
1758
+ }
1759
+
1760
+ /**
1761
+ * Given the popper offsets, generate an output similar to getBoundingClientRect
1762
+ * @function
1763
+ * @ignore
1764
+ * @argument {Object} popperOffsets
1765
+ * @returns {Object} ClientRect like output
1766
+ */
1767
+ function getPopperClientRect(popperOffsets) {
1768
+ var offsets = Object.assign({}, popperOffsets);
1769
+ offsets.right = offsets.left + offsets.width;
1770
+ offsets.bottom = offsets.top + offsets.height;
1771
+ return offsets;
1772
+ }
1773
+
1774
+ /**
1775
+ * Given an array and the key to find, returns its index
1776
+ * @function
1777
+ * @ignore
1778
+ * @argument {Array} arr
1779
+ * @argument keyToFind
1780
+ * @returns index or null
1781
+ */
1782
+ function getArrayKeyIndex(arr, keyToFind) {
1783
+ var i = 0,
1784
+ key;
1785
+ for (key in arr) {
1786
+ if (arr[key] === keyToFind) {
1787
+ return i;
1788
+ }
1789
+ i++;
1790
+ }
1791
+ return null;
1792
+ }
1793
+
1794
+ /**
1795
+ * Get CSS computed property of the given element
1796
+ * @function
1797
+ * @ignore
1798
+ * @argument {Eement} element
1799
+ * @argument {String} property
1800
+ */
1801
+ function getStyleComputedProperty(element, property) {
1802
+ // NOTE: 1 DOM access here
1803
+ var css = root.getComputedStyle(element, null);
1804
+ return css[property];
1805
+ }
1806
+
1807
+ /**
1808
+ * Returns the offset parent of the given element
1809
+ * @function
1810
+ * @ignore
1811
+ * @argument {Element} element
1812
+ * @returns {Element} offset parent
1813
+ */
1814
+ function getOffsetParent(element) {
1815
+ // NOTE: 1 DOM access here
1816
+ var offsetParent = element.offsetParent;
1817
+ return offsetParent === root.document.body || !offsetParent ? root.document.documentElement : offsetParent;
1818
+ }
1819
+
1820
+ /**
1821
+ * Returns the scrolling parent of the given element
1822
+ * @function
1823
+ * @ignore
1824
+ * @argument {Element} element
1825
+ * @returns {Element} offset parent
1826
+ */
1827
+ function getScrollParent(element) {
1828
+ var parent = element.parentNode;
1829
+
1830
+ if (!parent) {
1831
+ return element;
1832
+ }
1833
+
1834
+ if (parent === root.document) {
1835
+ // Firefox puts the scrollTOp value on `documentElement` instead of `body`, we then check which of them is
1836
+ // greater than 0 and return the proper element
1837
+ if (root.document.body.scrollTop || root.document.body.scrollLeft) {
1838
+ return root.document.body;
1839
+ } else {
1840
+ return root.document.documentElement;
1841
+ }
1842
+ }
1843
+
1844
+ // Firefox want us to check `-x` and `-y` variations as well
1845
+ if (['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow')) !== -1 || ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-x')) !== -1 || ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-y')) !== -1) {
1846
+ // If the detected scrollParent is body, we perform an additional check on its parentNode
1847
+ // in this way we'll get body if the browser is Chrome-ish, or documentElement otherwise
1848
+ // fixes issue #65
1849
+ return parent;
1850
+ }
1851
+ return getScrollParent(element.parentNode);
1852
+ }
1853
+
1854
+ /**
1855
+ * Check if the given element is fixed or is inside a fixed parent
1856
+ * @function
1857
+ * @ignore
1858
+ * @argument {Element} element
1859
+ * @argument {Element} customContainer
1860
+ * @returns {Boolean} answer to "isFixed?"
1861
+ */
1862
+ function isFixed(element) {
1863
+ if (element === root.document.body) {
1864
+ return false;
1865
+ }
1866
+ if (getStyleComputedProperty(element, 'position') === 'fixed') {
1867
+ return true;
1868
+ }
1869
+ return element.parentNode ? isFixed(element.parentNode) : element;
1870
+ }
1871
+
1872
+ /**
1873
+ * Set the style to the given popper
1874
+ * @function
1875
+ * @ignore
1876
+ * @argument {Element} element - Element to apply the style to
1877
+ * @argument {Object} styles - Object with a list of properties and values which will be applied to the element
1878
+ */
1879
+ function setStyle(element, styles) {
1880
+ function is_numeric(n) {
1881
+ return n !== '' && !isNaN(parseFloat(n)) && isFinite(n);
1882
+ }
1883
+ Object.keys(styles).forEach(function (prop) {
1884
+ var unit = '';
1885
+ // add unit if the value is numeric and is one of the following
1886
+ if (['width', 'height', 'top', 'right', 'bottom', 'left'].indexOf(prop) !== -1 && is_numeric(styles[prop])) {
1887
+ unit = 'px';
1888
+ }
1889
+ element.style[prop] = styles[prop] + unit;
1890
+ });
1891
+ }
1892
+
1893
+ /**
1894
+ * Check if the given variable is a function
1895
+ * @function
1896
+ * @ignore
1897
+ * @argument {*} functionToCheck - variable to check
1898
+ * @returns {Boolean} answer to: is a function?
1899
+ */
1900
+ function isFunction(functionToCheck) {
1901
+ var getType = {};
1902
+ return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
1903
+ }
1904
+
1905
+ /**
1906
+ * Get the position of the given element, relative to its offset parent
1907
+ * @function
1908
+ * @ignore
1909
+ * @param {Element} element
1910
+ * @return {Object} position - Coordinates of the element and its `scrollTop`
1911
+ */
1912
+ function getOffsetRect(element) {
1913
+ var elementRect = {
1914
+ width: element.offsetWidth,
1915
+ height: element.offsetHeight,
1916
+ left: element.offsetLeft,
1917
+ top: element.offsetTop
1918
+ };
1919
+
1920
+ elementRect.right = elementRect.left + elementRect.width;
1921
+ elementRect.bottom = elementRect.top + elementRect.height;
1922
+
1923
+ // position
1924
+ return elementRect;
1925
+ }
1926
+
1927
+ /**
1928
+ * Get bounding client rect of given element
1929
+ * @function
1930
+ * @ignore
1931
+ * @param {HTMLElement} element
1932
+ * @return {Object} client rect
1933
+ */
1934
+ function getBoundingClientRect(element) {
1935
+ var rect = element.getBoundingClientRect();
1936
+
1937
+ // whether the IE version is lower than 11
1938
+ var isIE = navigator.userAgent.indexOf("MSIE") != -1;
1939
+
1940
+ // fix ie document bounding top always 0 bug
1941
+ var rectTop = isIE && element.tagName === 'HTML' ? -element.scrollTop : rect.top;
1942
+
1943
+ return {
1944
+ left: rect.left,
1945
+ top: rectTop,
1946
+ right: rect.right,
1947
+ bottom: rect.bottom,
1948
+ width: rect.right - rect.left,
1949
+ height: rect.bottom - rectTop
1950
+ };
1951
+ }
1952
+
1953
+ /**
1954
+ * Given an element and one of its parents, return the offset
1955
+ * @function
1956
+ * @ignore
1957
+ * @param {HTMLElement} element
1958
+ * @param {HTMLElement} parent
1959
+ * @return {Object} rect
1960
+ */
1961
+ function getOffsetRectRelativeToCustomParent(element, parent, fixed) {
1962
+ var elementRect = getBoundingClientRect(element);
1963
+ var parentRect = getBoundingClientRect(parent);
1964
+
1965
+ if (fixed) {
1966
+ var scrollParent = getScrollParent(parent);
1967
+ parentRect.top += scrollParent.scrollTop;
1968
+ parentRect.bottom += scrollParent.scrollTop;
1969
+ parentRect.left += scrollParent.scrollLeft;
1970
+ parentRect.right += scrollParent.scrollLeft;
1971
+ }
1972
+
1973
+ var rect = {
1974
+ top: elementRect.top - parentRect.top,
1975
+ left: elementRect.left - parentRect.left,
1976
+ bottom: elementRect.top - parentRect.top + elementRect.height,
1977
+ right: elementRect.left - parentRect.left + elementRect.width,
1978
+ width: elementRect.width,
1979
+ height: elementRect.height
1980
+ };
1981
+ return rect;
1982
+ }
1983
+
1984
+ /**
1985
+ * Get the prefixed supported property name
1986
+ * @function
1987
+ * @ignore
1988
+ * @argument {String} property (camelCase)
1989
+ * @returns {String} prefixed property (camelCase)
1990
+ */
1991
+ function getSupportedPropertyName(property) {
1992
+ var prefixes = ['', 'ms', 'webkit', 'moz', 'o'];
1993
+
1994
+ for (var i = 0; i < prefixes.length; i++) {
1995
+ var toCheck = prefixes[i] ? prefixes[i] + property.charAt(0).toUpperCase() + property.slice(1) : property;
1996
+ if (typeof root.document.body.style[toCheck] !== 'undefined') {
1997
+ return toCheck;
1998
+ }
1999
+ }
2000
+ return null;
2001
+ }
2002
+
2003
+ /**
2004
+ * The Object.assign() method is used to copy the values of all enumerable own properties from one or more source
2005
+ * objects to a target object. It will return the target object.
2006
+ * This polyfill doesn't support symbol properties, since ES5 doesn't have symbols anyway
2007
+ * Source: https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign
2008
+ * @function
2009
+ * @ignore
2010
+ */
2011
+ if (!Object.assign) {
2012
+ Object.defineProperty(Object, 'assign', {
2013
+ enumerable: false,
2014
+ configurable: true,
2015
+ writable: true,
2016
+ value: function value(target) {
2017
+ if (target === undefined || target === null) {
2018
+ throw new TypeError('Cannot convert first argument to object');
2019
+ }
2020
+
2021
+ var to = Object(target);
2022
+ for (var i = 1; i < arguments.length; i++) {
2023
+ var nextSource = arguments[i];
2024
+ if (nextSource === undefined || nextSource === null) {
2025
+ continue;
2026
+ }
2027
+ nextSource = Object(nextSource);
2028
+
2029
+ var keysArray = Object.keys(nextSource);
2030
+ for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex++) {
2031
+ var nextKey = keysArray[nextIndex];
2032
+ var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);
2033
+ if (desc !== undefined && desc.enumerable) {
2034
+ to[nextKey] = nextSource[nextKey];
2035
+ }
2036
+ }
2037
+ }
2038
+ return to;
2039
+ }
2040
+ });
2041
+ }
2042
+
2043
+ return Popper;
2044
+ });
2045
+
2046
+ /***/ }),
2047
+
2048
+ /***/ 7:
2049
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
2050
+
2051
+ "use strict";
2052
+ /* harmony default export */ __webpack_exports__["a"] = (function (target) {
2053
+ for (var i = 1, j = arguments.length; i < j; i++) {
2054
+ var source = arguments[i] || {};
2055
+ for (var prop in source) {
2056
+ if (source.hasOwnProperty(prop)) {
2057
+ var value = source[prop];
2058
+ if (value !== undefined) {
2059
+ target[prop] = value;
2060
+ }
2061
+ }
2062
+ }
2063
+ }
2064
+
2065
+ return target;
2066
+ });;
2067
+
2068
+ /***/ }),
2069
+
2070
+ /***/ 8:
2071
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
2072
+
2073
+ "use strict";
2074
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(0);
2075
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_0__);
2076
+
2077
+
2078
+ var scrollBarWidth = void 0;
2079
+
2080
+ /* harmony default export */ __webpack_exports__["a"] = (function () {
2081
+ if (vue__WEBPACK_IMPORTED_MODULE_0___default.a.prototype.$isServer) return 0;
2082
+ if (scrollBarWidth !== undefined) return scrollBarWidth;
2083
+
2084
+ var outer = document.createElement('div');
2085
+ outer.className = 'el-scrollbar__wrap';
2086
+ outer.style.visibility = 'hidden';
2087
+ outer.style.width = '100px';
2088
+ outer.style.position = 'absolute';
2089
+ outer.style.top = '-9999px';
2090
+ document.body.appendChild(outer);
2091
+
2092
+ var widthNoScroll = outer.offsetWidth;
2093
+ outer.style.overflow = 'scroll';
2094
+
2095
+ var inner = document.createElement('div');
2096
+ inner.style.width = '100%';
2097
+ outer.appendChild(inner);
2098
+
2099
+ var widthWithScroll = inner.offsetWidth;
2100
+ outer.parentNode.removeChild(outer);
2101
+ scrollBarWidth = widthNoScroll - widthWithScroll;
2102
+
2103
+ return scrollBarWidth;
2104
+ });;
2105
+
2106
+ /***/ }),
2107
+
2108
+ /***/ 9:
2109
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
2110
+
2111
+ "use strict";
2112
+
2113
+ // EXPORTS
2114
+ __webpack_require__.d(__webpack_exports__, "a", function() { return /* reexport */ popup_manager; });
2115
+
2116
+ // EXTERNAL MODULE: external "vue"
2117
+ var external_vue_ = __webpack_require__(0);
2118
+ var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_);
2119
+
2120
+ // EXTERNAL MODULE: ./src/utils/merge.js
2121
+ var merge = __webpack_require__(7);
2122
+
2123
+ // EXTERNAL MODULE: ./src/utils/dom.js
2124
+ var utils_dom = __webpack_require__(1);
2125
+
2126
+ // CONCATENATED MODULE: ./src/utils/popup/popup-manager.js
2127
+
2128
+
2129
+
2130
+ var hasModal = false;
2131
+ var hasInitZIndex = false;
2132
+ var popup_manager_zIndex = void 0;
2133
+
2134
+ var popup_manager_getModal = function getModal() {
2135
+ if (external_vue_default.a.prototype.$isServer) return;
2136
+ var modalDom = PopupManager.modalDom;
2137
+ if (modalDom) {
2138
+ hasModal = true;
2139
+ } else {
2140
+ hasModal = false;
2141
+ modalDom = document.createElement('div');
2142
+ PopupManager.modalDom = modalDom;
2143
+
2144
+ modalDom.addEventListener('touchmove', function (event) {
2145
+ event.preventDefault();
2146
+ event.stopPropagation();
2147
+ });
2148
+
2149
+ modalDom.addEventListener('click', function () {
2150
+ PopupManager.doOnModalClick && PopupManager.doOnModalClick();
2151
+ });
2152
+ }
2153
+
2154
+ return modalDom;
2155
+ };
2156
+
2157
+ var instances = {};
2158
+
2159
+ var PopupManager = {
2160
+ modalFade: true,
2161
+
2162
+ getInstance: function getInstance(id) {
2163
+ return instances[id];
2164
+ },
2165
+
2166
+ register: function register(id, instance) {
2167
+ if (id && instance) {
2168
+ instances[id] = instance;
2169
+ }
2170
+ },
2171
+
2172
+ deregister: function deregister(id) {
2173
+ if (id) {
2174
+ instances[id] = null;
2175
+ delete instances[id];
2176
+ }
2177
+ },
2178
+
2179
+ nextZIndex: function nextZIndex() {
2180
+ return PopupManager.zIndex++;
2181
+ },
2182
+
2183
+ modalStack: [],
2184
+
2185
+ doOnModalClick: function doOnModalClick() {
2186
+ var topItem = PopupManager.modalStack[PopupManager.modalStack.length - 1];
2187
+ if (!topItem) return;
2188
+
2189
+ var instance = PopupManager.getInstance(topItem.id);
2190
+ if (instance && instance.closeOnClickModal) {
2191
+ instance.close();
2192
+ }
2193
+ },
2194
+
2195
+ openModal: function openModal(id, zIndex, dom, modalClass, modalFade) {
2196
+ if (external_vue_default.a.prototype.$isServer) return;
2197
+ if (!id || zIndex === undefined) return;
2198
+ this.modalFade = modalFade;
2199
+
2200
+ var modalStack = this.modalStack;
2201
+
2202
+ for (var i = 0, j = modalStack.length; i < j; i++) {
2203
+ var item = modalStack[i];
2204
+ if (item.id === id) {
2205
+ return;
2206
+ }
2207
+ }
2208
+
2209
+ var modalDom = popup_manager_getModal();
2210
+
2211
+ Object(utils_dom["a" /* addClass */])(modalDom, 'v-modal');
2212
+ if (this.modalFade && !hasModal) {
2213
+ Object(utils_dom["a" /* addClass */])(modalDom, 'v-modal-enter');
2214
+ }
2215
+ if (modalClass) {
2216
+ var classArr = modalClass.trim().split(/\s+/);
2217
+ classArr.forEach(function (item) {
2218
+ return Object(utils_dom["a" /* addClass */])(modalDom, item);
2219
+ });
2220
+ }
2221
+ setTimeout(function () {
2222
+ Object(utils_dom["i" /* removeClass */])(modalDom, 'v-modal-enter');
2223
+ }, 200);
2224
+
2225
+ if (dom && dom.parentNode && dom.parentNode.nodeType !== 11) {
2226
+ dom.parentNode.appendChild(modalDom);
2227
+ } else {
2228
+ document.body.appendChild(modalDom);
2229
+ }
2230
+
2231
+ if (zIndex) {
2232
+ modalDom.style.zIndex = zIndex;
2233
+ }
2234
+ modalDom.tabIndex = 0;
2235
+ modalDom.style.display = '';
2236
+
2237
+ this.modalStack.push({ id: id, zIndex: zIndex, modalClass: modalClass });
2238
+ },
2239
+
2240
+ closeModal: function closeModal(id) {
2241
+ var modalStack = this.modalStack;
2242
+ var modalDom = popup_manager_getModal();
2243
+
2244
+ if (modalStack.length > 0) {
2245
+ var topItem = modalStack[modalStack.length - 1];
2246
+ if (topItem.id === id) {
2247
+ if (topItem.modalClass) {
2248
+ var classArr = topItem.modalClass.trim().split(/\s+/);
2249
+ classArr.forEach(function (item) {
2250
+ return Object(utils_dom["i" /* removeClass */])(modalDom, item);
2251
+ });
2252
+ }
2253
+
2254
+ modalStack.pop();
2255
+ if (modalStack.length > 0) {
2256
+ modalDom.style.zIndex = modalStack[modalStack.length - 1].zIndex;
2257
+ }
2258
+ } else {
2259
+ for (var i = modalStack.length - 1; i >= 0; i--) {
2260
+ if (modalStack[i].id === id) {
2261
+ modalStack.splice(i, 1);
2262
+ break;
2263
+ }
2264
+ }
2265
+ }
2266
+ }
2267
+
2268
+ if (modalStack.length === 0) {
2269
+ if (this.modalFade) {
2270
+ Object(utils_dom["a" /* addClass */])(modalDom, 'v-modal-leave');
2271
+ }
2272
+ setTimeout(function () {
2273
+ if (modalStack.length === 0) {
2274
+ if (modalDom.parentNode) modalDom.parentNode.removeChild(modalDom);
2275
+ modalDom.style.display = 'none';
2276
+ PopupManager.modalDom = undefined;
2277
+ }
2278
+ Object(utils_dom["i" /* removeClass */])(modalDom, 'v-modal-leave');
2279
+ }, 200);
2280
+ }
2281
+ }
2282
+ };
2283
+
2284
+ Object.defineProperty(PopupManager, 'zIndex', {
2285
+ configurable: true,
2286
+ get: function get() {
2287
+ if (!hasInitZIndex) {
2288
+ popup_manager_zIndex = popup_manager_zIndex || (external_vue_default.a.prototype.$ELEMENT || {}).zIndex || 2000;
2289
+ hasInitZIndex = true;
2290
+ }
2291
+ return popup_manager_zIndex;
2292
+ },
2293
+ set: function set(value) {
2294
+ popup_manager_zIndex = value;
2295
+ }
2296
+ });
2297
+
2298
+ var popup_manager_getTopPopup = function getTopPopup() {
2299
+ if (external_vue_default.a.prototype.$isServer) return;
2300
+ if (PopupManager.modalStack.length > 0) {
2301
+ var topPopup = PopupManager.modalStack[PopupManager.modalStack.length - 1];
2302
+ if (!topPopup) return;
2303
+ var instance = PopupManager.getInstance(topPopup.id);
2304
+
2305
+ return instance;
2306
+ }
2307
+ };
2308
+
2309
+ if (!external_vue_default.a.prototype.$isServer) {
2310
+ // handle `esc` key when the popup is shown
2311
+ window.addEventListener('keydown', function (event) {
2312
+ if (event.keyCode === 27) {
2313
+ var topPopup = popup_manager_getTopPopup();
2314
+
2315
+ if (topPopup && topPopup.closeOnPressEscape) {
2316
+ topPopup.handleClose ? topPopup.handleClose() : topPopup.handleAction ? topPopup.handleAction('cancel') : topPopup.close();
2317
+ }
2318
+ }
2319
+ });
2320
+ }
2321
+
2322
+ /* harmony default export */ var popup_manager = (PopupManager);
2323
+ // EXTERNAL MODULE: ./src/utils/scrollbar-width.js
2324
+ var scrollbar_width = __webpack_require__(8);
2325
+
2326
+ // CONCATENATED MODULE: ./src/utils/popup/index.js
2327
+
2328
+
2329
+
2330
+
2331
+
2332
+
2333
+ var idSeed = 1;
2334
+
2335
+ var scrollBarWidth = void 0;
2336
+
2337
+ /* harmony default export */ var popup = __webpack_exports__["b"] = ({
2338
+ props: {
2339
+ visible: {
2340
+ type: Boolean,
2341
+ default: false
2342
+ },
2343
+ openDelay: {},
2344
+ closeDelay: {},
2345
+ zIndex: {},
2346
+ modal: {
2347
+ type: Boolean,
2348
+ default: false
2349
+ },
2350
+ modalFade: {
2351
+ type: Boolean,
2352
+ default: true
2353
+ },
2354
+ modalClass: {},
2355
+ modalAppendToBody: {
2356
+ type: Boolean,
2357
+ default: false
2358
+ },
2359
+ lockScroll: {
2360
+ type: Boolean,
2361
+ default: true
2362
+ },
2363
+ closeOnPressEscape: {
2364
+ type: Boolean,
2365
+ default: false
2366
+ },
2367
+ closeOnClickModal: {
2368
+ type: Boolean,
2369
+ default: false
2370
+ }
2371
+ },
2372
+
2373
+ beforeMount: function beforeMount() {
2374
+ this._popupId = 'popup-' + idSeed++;
2375
+ popup_manager.register(this._popupId, this);
2376
+ },
2377
+ beforeDestroy: function beforeDestroy() {
2378
+ popup_manager.deregister(this._popupId);
2379
+ popup_manager.closeModal(this._popupId);
2380
+
2381
+ this.restoreBodyStyle();
2382
+ },
2383
+ data: function data() {
2384
+ return {
2385
+ opened: false,
2386
+ bodyPaddingRight: null,
2387
+ computedBodyPaddingRight: 0,
2388
+ withoutHiddenClass: true,
2389
+ rendered: false
2390
+ };
2391
+ },
2392
+
2393
+
2394
+ watch: {
2395
+ visible: function visible(val) {
2396
+ var _this = this;
2397
+
2398
+ if (val) {
2399
+ if (this._opening) return;
2400
+ if (!this.rendered) {
2401
+ this.rendered = true;
2402
+ external_vue_default.a.nextTick(function () {
2403
+ _this.open();
2404
+ });
2405
+ } else {
2406
+ this.open();
2407
+ }
2408
+ } else {
2409
+ this.close();
2410
+ }
2411
+ }
2412
+ },
2413
+
2414
+ methods: {
2415
+ open: function open(options) {
2416
+ var _this2 = this;
2417
+
2418
+ if (!this.rendered) {
2419
+ this.rendered = true;
2420
+ }
2421
+
2422
+ var props = Object(merge["a" /* default */])({}, this.$props || this, options);
2423
+
2424
+ if (this._closeTimer) {
2425
+ clearTimeout(this._closeTimer);
2426
+ this._closeTimer = null;
2427
+ }
2428
+ clearTimeout(this._openTimer);
2429
+
2430
+ var openDelay = Number(props.openDelay);
2431
+ if (openDelay > 0) {
2432
+ this._openTimer = setTimeout(function () {
2433
+ _this2._openTimer = null;
2434
+ _this2.doOpen(props);
2435
+ }, openDelay);
2436
+ } else {
2437
+ this.doOpen(props);
2438
+ }
2439
+ },
2440
+ doOpen: function doOpen(props) {
2441
+ if (this.$isServer) return;
2442
+ if (this.willOpen && !this.willOpen()) return;
2443
+ if (this.opened) return;
2444
+
2445
+ this._opening = true;
2446
+
2447
+ var dom = this.$el;
2448
+
2449
+ var modal = props.modal;
2450
+
2451
+ var zIndex = props.zIndex;
2452
+ if (zIndex) {
2453
+ popup_manager.zIndex = zIndex;
2454
+ }
2455
+
2456
+ if (modal) {
2457
+ if (this._closing) {
2458
+ popup_manager.closeModal(this._popupId);
2459
+ this._closing = false;
2460
+ }
2461
+ popup_manager.openModal(this._popupId, popup_manager.nextZIndex(), this.modalAppendToBody ? undefined : dom, props.modalClass, props.modalFade);
2462
+ if (props.lockScroll) {
2463
+ this.withoutHiddenClass = !Object(utils_dom["d" /* hasClass */])(document.body, 'el-popup-parent--hidden');
2464
+ if (this.withoutHiddenClass) {
2465
+ this.bodyPaddingRight = document.body.style.paddingRight;
2466
+ this.computedBodyPaddingRight = parseInt(Object(utils_dom["c" /* getStyle */])(document.body, 'paddingRight'), 10);
2467
+ }
2468
+ scrollBarWidth = Object(scrollbar_width["a" /* default */])();
2469
+ var bodyHasOverflow = document.documentElement.clientHeight < document.body.scrollHeight;
2470
+ var bodyOverflowY = Object(utils_dom["c" /* getStyle */])(document.body, 'overflowY');
2471
+ if (scrollBarWidth > 0 && (bodyHasOverflow || bodyOverflowY === 'scroll') && this.withoutHiddenClass) {
2472
+ document.body.style.paddingRight = this.computedBodyPaddingRight + scrollBarWidth + 'px';
2473
+ }
2474
+ Object(utils_dom["a" /* addClass */])(document.body, 'el-popup-parent--hidden');
2475
+ }
2476
+ }
2477
+
2478
+ if (getComputedStyle(dom).position === 'static') {
2479
+ dom.style.position = 'absolute';
2480
+ }
2481
+
2482
+ dom.style.zIndex = popup_manager.nextZIndex();
2483
+ this.opened = true;
2484
+
2485
+ this.onOpen && this.onOpen();
2486
+
2487
+ this.doAfterOpen();
2488
+ },
2489
+ doAfterOpen: function doAfterOpen() {
2490
+ this._opening = false;
2491
+ },
2492
+ close: function close() {
2493
+ var _this3 = this;
2494
+
2495
+ if (this.willClose && !this.willClose()) return;
2496
+
2497
+ if (this._openTimer !== null) {
2498
+ clearTimeout(this._openTimer);
2499
+ this._openTimer = null;
2500
+ }
2501
+ clearTimeout(this._closeTimer);
2502
+
2503
+ var closeDelay = Number(this.closeDelay);
2504
+
2505
+ if (closeDelay > 0) {
2506
+ this._closeTimer = setTimeout(function () {
2507
+ _this3._closeTimer = null;
2508
+ _this3.doClose();
2509
+ }, closeDelay);
2510
+ } else {
2511
+ this.doClose();
2512
+ }
2513
+ },
2514
+ doClose: function doClose() {
2515
+ this._closing = true;
2516
+
2517
+ this.onClose && this.onClose();
2518
+
2519
+ if (this.lockScroll) {
2520
+ setTimeout(this.restoreBodyStyle, 200);
2521
+ }
2522
+
2523
+ this.opened = false;
2524
+
2525
+ this.doAfterClose();
2526
+ },
2527
+ doAfterClose: function doAfterClose() {
2528
+ popup_manager.closeModal(this._popupId);
2529
+ this._closing = false;
2530
+ },
2531
+ restoreBodyStyle: function restoreBodyStyle() {
2532
+ if (this.modal && this.withoutHiddenClass) {
2533
+ document.body.style.paddingRight = this.bodyPaddingRight;
2534
+ Object(utils_dom["i" /* removeClass */])(document.body, 'el-popup-parent--hidden');
2535
+ }
2536
+ this.withoutHiddenClass = true;
2537
+ }
2538
+ }
2539
+ });
2540
+
2541
+
2542
+
341
2543
  /***/ })
342
2544
 
343
2545
  /******/ });