module.exports = /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ /******/ // Check if module is in cache /******/ if(installedModules[moduleId]) { /******/ return installedModules[moduleId].exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { /******/ i: moduleId, /******/ l: false, /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); /******/ /******/ // Flag the module as loaded /******/ module.l = true; /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /******/ /******/ // expose the modules object (__webpack_modules__) /******/ __webpack_require__.m = modules; /******/ /******/ // expose the module cache /******/ __webpack_require__.c = installedModules; /******/ /******/ // define getter function for harmony exports /******/ __webpack_require__.d = function(exports, name, getter) { /******/ if(!__webpack_require__.o(exports, name)) { /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); /******/ } /******/ }; /******/ /******/ // define __esModule on exports /******/ __webpack_require__.r = function(exports) { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ /******/ // create a fake namespace object /******/ // mode & 1: value is a module id, require it /******/ // mode & 2: merge all properties of value into the ns /******/ // mode & 4: return value when already ns object /******/ // mode & 8|1: behave like require /******/ __webpack_require__.t = function(value, mode) { /******/ if(mode & 1) value = __webpack_require__(value); /******/ if(mode & 8) return value; /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; /******/ var ns = Object.create(null); /******/ __webpack_require__.r(ns); /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); /******/ return ns; /******/ }; /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = function(module) { /******/ var getter = module && module.__esModule ? /******/ function getDefault() { return module['default']; } : /******/ function getModuleExports() { return module; }; /******/ __webpack_require__.d(getter, 'a', getter); /******/ return getter; /******/ }; /******/ /******/ // Object.prototype.hasOwnProperty.call /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; /******/ /******/ // __webpack_public_path__ /******/ __webpack_require__.p = "/dist/"; /******/ /******/ /******/ // Load entry module and return exports /******/ return __webpack_require__(__webpack_require__.s = 45); /******/ }) /************************************************************************/ /******/ ([ /* 0 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/date-util"); /***/ }), /* 1 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/dom"); /***/ }), /* 2 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/util"); /***/ }), /* 3 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/mixins/emitter"); /***/ }), /* 4 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/mixins/locale"); /***/ }), /* 5 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/vue-popper"); /***/ }), /* 6 */ /***/ (function(module, exports) { module.exports = require("vue"); /***/ }), /* 7 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/merge"); /***/ }), /* 8 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/input"); /***/ }), /* 9 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/mixins/migrating"); /***/ }), /* 10 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/clickoutside"); /***/ }), /* 11 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/locale"); /***/ }), /* 12 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/button"); /***/ }), /* 13 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/resize-event"); /***/ }), /* 14 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/popup"); /***/ }), /* 15 */ /***/ (function(module, exports) { module.exports = require("throttle-debounce/debounce"); /***/ }), /* 16 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/checkbox"); /***/ }), /* 17 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/scrollbar"); /***/ }), /* 18 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/types"); /***/ }), /* 19 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/shared"); /***/ }), /* 20 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/date"); /***/ }), /* 21 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/transitions/collapse-transition"); /***/ }), /* 22 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/mixins/focus"); /***/ }), /* 23 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/vdom"); /***/ }), /* 24 */ /***/ (function(module, exports) { module.exports = require("babel-helper-vue-jsx-merge-props"); /***/ }), /* 25 */ /***/ (function(module, exports) { module.exports = require("throttle-debounce/throttle"); /***/ }), /* 26 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/tooltip"); /***/ }), /* 27 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/scroll-into-view"); /***/ }), /* 28 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/aria-utils"); /***/ }), /* 29 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/button-group"); /***/ }), /* 30 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/tag"); /***/ }), /* 31 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/scrollbar-width"); /***/ }), /* 32 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/checkbox-group"); /***/ }), /* 33 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/after-leave"); /***/ }), /* 34 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/progress"); /***/ }), /* 35 */ /***/ (function(module, exports) { module.exports = require("throttle-debounce"); /***/ }), /* 36 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/select"); /***/ }), /* 37 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/option"); /***/ }), /* 38 */ /***/ (function(module, exports) { module.exports = require("normalize-wheel"); /***/ }), /* 39 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/utils/aria-dialog"); /***/ }), /* 40 */ /***/ (function(module, exports) { module.exports = require("async-validator"); /***/ }), /* 41 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/input-number"); /***/ }), /* 42 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/cascader-panel"); /***/ }), /* 43 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/radio"); /***/ }), /* 44 */ /***/ (function(module, exports) { module.exports = require("element-ui/lib/popover"); /***/ }), /* 45 */ /***/ (function(module, exports, __webpack_require__) { module.exports = __webpack_require__(46); /***/ }), /* 46 */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/pagination/src/pager.vue?vue&type=template&id=7274f267& var pagervue_type_template_id_7274f267_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "ul", { staticClass: "el-pager", on: { click: _vm.onPagerClick } }, [ _vm.pageCount > 0 ? _c( "li", { staticClass: "number", class: { active: _vm.currentPage === 1, disabled: _vm.disabled } }, [_vm._v("1")] ) : _vm._e(), _vm.showPrevMore ? _c("li", { staticClass: "el-icon more btn-quickprev", class: [_vm.quickprevIconClass, { disabled: _vm.disabled }], on: { mouseenter: function($event) { _vm.onMouseenter("left") }, mouseleave: function($event) { _vm.quickprevIconClass = "el-icon-more" } } }) : _vm._e(), _vm._l(_vm.pagers, function(pager) { return _c( "li", { key: pager, staticClass: "number", class: { active: _vm.currentPage === pager, disabled: _vm.disabled } }, [_vm._v(_vm._s(pager))] ) }), _vm.showNextMore ? _c("li", { staticClass: "el-icon more btn-quicknext", class: [_vm.quicknextIconClass, { disabled: _vm.disabled }], on: { mouseenter: function($event) { _vm.onMouseenter("right") }, mouseleave: function($event) { _vm.quicknextIconClass = "el-icon-more" } } }) : _vm._e(), _vm.pageCount > 1 ? _c( "li", { staticClass: "number", class: { active: _vm.currentPage === _vm.pageCount, disabled: _vm.disabled } }, [_vm._v(_vm._s(_vm.pageCount))] ) : _vm._e() ], 2 ) } var staticRenderFns = [] pagervue_type_template_id_7274f267_render._withStripped = true // CONCATENATED MODULE: ./packages/pagination/src/pager.vue?vue&type=template&id=7274f267& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/pagination/src/pager.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var pagervue_type_script_lang_js_ = ({ name: 'ElPager', props: { currentPage: Number, pageCount: Number, pagerCount: Number, disabled: Boolean }, watch: { showPrevMore: function showPrevMore(val) { if (!val) this.quickprevIconClass = 'el-icon-more'; }, showNextMore: function showNextMore(val) { if (!val) this.quicknextIconClass = 'el-icon-more'; } }, methods: { onPagerClick: function onPagerClick(event) { var target = event.target; if (target.tagName === 'UL' || this.disabled) { return; } var newPage = Number(event.target.textContent); var pageCount = this.pageCount; var currentPage = this.currentPage; var pagerCountOffset = this.pagerCount - 2; if (target.className.indexOf('more') !== -1) { if (target.className.indexOf('quickprev') !== -1) { newPage = currentPage - pagerCountOffset; } else if (target.className.indexOf('quicknext') !== -1) { newPage = currentPage + pagerCountOffset; } } /* istanbul ignore if */ if (!isNaN(newPage)) { if (newPage < 1) { newPage = 1; } if (newPage > pageCount) { newPage = pageCount; } } if (newPage !== currentPage) { this.$emit('change', newPage); } }, onMouseenter: function onMouseenter(direction) { if (this.disabled) return; if (direction === 'left') { this.quickprevIconClass = 'el-icon-d-arrow-left'; } else { this.quicknextIconClass = 'el-icon-d-arrow-right'; } } }, computed: { pagers: function pagers() { var pagerCount = this.pagerCount; var halfPagerCount = (pagerCount - 1) / 2; var currentPage = Number(this.currentPage); var pageCount = Number(this.pageCount); var showPrevMore = false; var showNextMore = false; if (pageCount > pagerCount) { if (currentPage > pagerCount - halfPagerCount) { showPrevMore = true; } if (currentPage < pageCount - halfPagerCount) { showNextMore = true; } } var array = []; if (showPrevMore && !showNextMore) { var startPage = pageCount - (pagerCount - 2); for (var i = startPage; i < pageCount; i++) { array.push(i); } } else if (!showPrevMore && showNextMore) { for (var _i = 2; _i < pagerCount; _i++) { array.push(_i); } } else if (showPrevMore && showNextMore) { var offset = Math.floor(pagerCount / 2) - 1; for (var _i2 = currentPage - offset; _i2 <= currentPage + offset; _i2++) { array.push(_i2); } } else { for (var _i3 = 2; _i3 < pageCount; _i3++) { array.push(_i3); } } this.showPrevMore = showPrevMore; this.showNextMore = showNextMore; return array; } }, data: function data() { return { current: null, showPrevMore: false, showNextMore: false, quicknextIconClass: 'el-icon-more', quickprevIconClass: 'el-icon-more' }; } }); // CONCATENATED MODULE: ./packages/pagination/src/pager.vue?vue&type=script&lang=js& /* harmony default export */ var src_pagervue_type_script_lang_js_ = (pagervue_type_script_lang_js_); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js /* globals __VUE_SSR_CONTEXT__ */ // IMPORTANT: Do NOT use ES2015 features in this file (except for modules). // This module is a runtime utility for cleaner component module output and will // be included in the final webpack user bundle. function normalizeComponent ( scriptExports, render, staticRenderFns, functionalTemplate, injectStyles, scopeId, moduleIdentifier, /* server only */ shadowMode /* vue-cli only */ ) { // Vue.extend constructor export interop var options = typeof scriptExports === 'function' ? scriptExports.options : scriptExports // render functions if (render) { options.render = render options.staticRenderFns = staticRenderFns options._compiled = true } // functional template if (functionalTemplate) { options.functional = true } // scopedId if (scopeId) { options._scopeId = 'data-v-' + scopeId } var hook if (moduleIdentifier) { // server build hook = function (context) { // 2.3 injection context = context || // cached call (this.$vnode && this.$vnode.ssrContext) || // stateful (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional // 2.2 with runInNewContext: true if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { context = __VUE_SSR_CONTEXT__ } // inject component styles if (injectStyles) { injectStyles.call(this, context) } // register component module identifier for async chunk inferrence if (context && context._registeredComponents) { context._registeredComponents.add(moduleIdentifier) } } // used by ssr in case component is cached and beforeCreate // never gets called options._ssrRegister = hook } else if (injectStyles) { hook = shadowMode ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } : injectStyles } if (hook) { if (options.functional) { // for template-only hot-reload because in that case the render fn doesn't // go through the normalizer options._injectStyles = hook // register for functioal component in vue file var originalRender = options.render options.render = function renderWithStyleInjection (h, context) { hook.call(context) return originalRender(h, context) } } else { // inject component registration as beforeCreate hook var existing = options.beforeCreate options.beforeCreate = existing ? [].concat(existing, hook) : [hook] } } return { exports: scriptExports, options: options } } // CONCATENATED MODULE: ./packages/pagination/src/pager.vue /* normalize component */ var component = normalizeComponent( src_pagervue_type_script_lang_js_, pagervue_type_template_id_7274f267_render, staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var api; } component.options.__file = "packages/pagination/src/pager.vue" /* harmony default export */ var pager = (component.exports); // EXTERNAL MODULE: external "element-ui/lib/select" var select_ = __webpack_require__(36); var select_default = /*#__PURE__*/__webpack_require__.n(select_); // EXTERNAL MODULE: external "element-ui/lib/option" var option_ = __webpack_require__(37); var option_default = /*#__PURE__*/__webpack_require__.n(option_); // EXTERNAL MODULE: external "element-ui/lib/input" var input_ = __webpack_require__(8); var input_default = /*#__PURE__*/__webpack_require__.n(input_); // EXTERNAL MODULE: external "element-ui/lib/mixins/locale" var locale_ = __webpack_require__(4); var locale_default = /*#__PURE__*/__webpack_require__.n(locale_); // EXTERNAL MODULE: external "element-ui/lib/utils/util" var util_ = __webpack_require__(2); // CONCATENATED MODULE: ./packages/pagination/src/pagination.js /* harmony default export */ var pagination = ({ name: 'ElPagination', props: { pageSize: { type: Number, default: 10 }, small: Boolean, total: Number, pageCount: Number, pagerCount: { type: Number, validator: function validator(value) { return (value | 0) === value && value > 4 && value < 22 && value % 2 === 1; }, default: 7 }, currentPage: { type: Number, default: 1 }, layout: { default: 'prev, pager, next, jumper, ->, total' }, pageSizes: { type: Array, default: function _default() { return [10, 20, 30, 40, 50, 100]; } }, popperClass: String, prevText: String, nextText: String, background: Boolean, disabled: Boolean, hideOnSinglePage: Boolean }, data: function data() { return { internalCurrentPage: 1, internalPageSize: 0, lastEmittedPage: -1, userChangePageSize: false }; }, render: function render(h) { var layout = this.layout; if (!layout) return null; if (this.hideOnSinglePage && (!this.internalPageCount || this.internalPageCount === 1)) return null; var template = h('div', { 'class': ['el-pagination', { 'is-background': this.background, 'el-pagination--small': this.small }] }); var TEMPLATE_MAP = { prev: h('prev'), jumper: h('jumper'), pager: h('pager', { attrs: { currentPage: this.internalCurrentPage, pageCount: this.internalPageCount, pagerCount: this.pagerCount, disabled: this.disabled }, on: { 'change': this.handleCurrentChange } }), next: h('next'), sizes: h('sizes', { attrs: { pageSizes: this.pageSizes } }), slot: h('slot', [this.$slots.default ? this.$slots.default : '']), total: h('total') }; var components = layout.split(',').map(function (item) { return item.trim(); }); var rightWrapper = h('div', { 'class': 'el-pagination__rightwrapper' }); var haveRightWrapper = false; template.children = template.children || []; rightWrapper.children = rightWrapper.children || []; components.forEach(function (compo) { if (compo === '->') { haveRightWrapper = true; return; } if (!haveRightWrapper) { template.children.push(TEMPLATE_MAP[compo]); } else { rightWrapper.children.push(TEMPLATE_MAP[compo]); } }); if (haveRightWrapper) { template.children.unshift(rightWrapper); } return template; }, components: { Prev: { render: function render(h) { return h( 'button', { attrs: { type: 'button', disabled: this.$parent.disabled || this.$parent.internalCurrentPage <= 1 }, 'class': 'btn-prev', on: { 'click': this.$parent.prev } }, [this.$parent.prevText ? h('span', [this.$parent.prevText]) : h('i', { 'class': 'el-icon el-icon-arrow-left' })] ); } }, Next: { render: function render(h) { return h( 'button', { attrs: { type: 'button', disabled: this.$parent.disabled || this.$parent.internalCurrentPage === this.$parent.internalPageCount || this.$parent.internalPageCount === 0 }, 'class': 'btn-next', on: { 'click': this.$parent.next } }, [this.$parent.nextText ? h('span', [this.$parent.nextText]) : h('i', { 'class': 'el-icon el-icon-arrow-right' })] ); } }, Sizes: { mixins: [locale_default.a], props: { pageSizes: Array }, watch: { pageSizes: { immediate: true, handler: function handler(newVal, oldVal) { if (Object(util_["valueEquals"])(newVal, oldVal)) return; if (Array.isArray(newVal)) { this.$parent.internalPageSize = newVal.indexOf(this.$parent.pageSize) > -1 ? this.$parent.pageSize : this.pageSizes[0]; } } } }, render: function render(h) { var _this = this; return h( 'span', { 'class': 'el-pagination__sizes' }, [h( 'el-select', { attrs: { value: this.$parent.internalPageSize, popperClass: this.$parent.popperClass || '', size: 'mini', disabled: this.$parent.disabled }, on: { 'input': this.handleChange } }, [this.pageSizes.map(function (item) { return h('el-option', { attrs: { value: item, label: item + _this.t('el.pagination.pagesize') } }); })] )] ); }, components: { ElSelect: select_default.a, ElOption: option_default.a }, methods: { handleChange: function handleChange(val) { if (val !== this.$parent.internalPageSize) { this.$parent.internalPageSize = val = parseInt(val, 10); this.$parent.userChangePageSize = true; this.$parent.$emit('update:pageSize', val); this.$parent.$emit('size-change', val); } } } }, Jumper: { mixins: [locale_default.a], components: { ElInput: input_default.a }, data: function data() { return { userInput: null }; }, watch: { '$parent.internalCurrentPage': function $parentInternalCurrentPage() { this.userInput = null; } }, methods: { handleKeyup: function handleKeyup(_ref) { var keyCode = _ref.keyCode, target = _ref.target; // Chrome, Safari, Firefox triggers change event on Enter // Hack for IE: https://github.com/ElemeFE/element/issues/11710 // Drop this method when we no longer supports IE if (keyCode === 13) { this.handleChange(target.value); } }, handleInput: function handleInput(value) { this.userInput = value; }, handleChange: function handleChange(value) { this.$parent.internalCurrentPage = this.$parent.getValidCurrentPage(value); this.$parent.emitChange(); this.userInput = null; } }, render: function render(h) { return h( 'span', { 'class': 'el-pagination__jump' }, [this.t('el.pagination.goto'), h('el-input', { 'class': 'el-pagination__editor is-in-pagination', attrs: { min: 1, max: this.$parent.internalPageCount, value: this.userInput !== null ? this.userInput : this.$parent.internalCurrentPage, type: 'number', disabled: this.$parent.disabled }, nativeOn: { 'keyup': this.handleKeyup }, on: { 'input': this.handleInput, 'change': this.handleChange } }), this.t('el.pagination.pageClassifier')] ); } }, Total: { mixins: [locale_default.a], render: function render(h) { return typeof this.$parent.total === 'number' ? h( 'span', { 'class': 'el-pagination__total' }, [this.t('el.pagination.total', { total: this.$parent.total })] ) : ''; } }, Pager: pager }, methods: { handleCurrentChange: function handleCurrentChange(val) { this.internalCurrentPage = this.getValidCurrentPage(val); this.userChangePageSize = true; this.emitChange(); }, prev: function prev() { if (this.disabled) return; var newVal = this.internalCurrentPage - 1; this.internalCurrentPage = this.getValidCurrentPage(newVal); this.$emit('prev-click', this.internalCurrentPage); this.emitChange(); }, next: function next() { if (this.disabled) return; var newVal = this.internalCurrentPage + 1; this.internalCurrentPage = this.getValidCurrentPage(newVal); this.$emit('next-click', this.internalCurrentPage); this.emitChange(); }, getValidCurrentPage: function getValidCurrentPage(value) { value = parseInt(value, 10); var havePageCount = typeof this.internalPageCount === 'number'; var resetValue = void 0; if (!havePageCount) { if (isNaN(value) || value < 1) resetValue = 1; } else { if (value < 1) { resetValue = 1; } else if (value > this.internalPageCount) { resetValue = this.internalPageCount; } } if (resetValue === undefined && isNaN(value)) { resetValue = 1; } else if (resetValue === 0) { resetValue = 1; } return resetValue === undefined ? value : resetValue; }, emitChange: function emitChange() { var _this2 = this; this.$nextTick(function () { if (_this2.internalCurrentPage !== _this2.lastEmittedPage || _this2.userChangePageSize) { _this2.$emit('current-change', _this2.internalCurrentPage); _this2.lastEmittedPage = _this2.internalCurrentPage; _this2.userChangePageSize = false; } }); } }, computed: { internalPageCount: function internalPageCount() { if (typeof this.total === 'number') { return Math.max(1, Math.ceil(this.total / this.internalPageSize)); } else if (typeof this.pageCount === 'number') { return Math.max(1, this.pageCount); } return null; } }, watch: { currentPage: { immediate: true, handler: function handler(val) { this.internalCurrentPage = this.getValidCurrentPage(val); } }, pageSize: { immediate: true, handler: function handler(val) { this.internalPageSize = isNaN(val) ? 10 : val; } }, internalCurrentPage: { immediate: true, handler: function handler(newVal) { this.$emit('update:currentPage', newVal); this.lastEmittedPage = -1; } }, internalPageCount: function internalPageCount(newVal) { /* istanbul ignore if */ var oldPage = this.internalCurrentPage; if (newVal > 0 && oldPage === 0) { this.internalCurrentPage = 1; } else if (oldPage > newVal) { this.internalCurrentPage = newVal === 0 ? 1 : newVal; this.userChangePageSize && this.emitChange(); } this.userChangePageSize = false; } } }); // CONCATENATED MODULE: ./packages/pagination/index.js /* istanbul ignore next */ pagination.install = function (Vue) { Vue.component(pagination.name, pagination); }; /* harmony default export */ var packages_pagination = (pagination); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dialog/src/component.vue?vue&type=template&id=60140e62& var componentvue_type_template_id_60140e62_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "dialog-fade" }, on: { "after-enter": _vm.afterEnter, "after-leave": _vm.afterLeave } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-dialog__wrapper", on: { click: function($event) { if ($event.target !== $event.currentTarget) { return null } return _vm.handleWrapperClick($event) } } }, [ _c( "div", { key: _vm.key, ref: "dialog", class: [ "el-dialog", { "is-fullscreen": _vm.fullscreen, "el-dialog--center": _vm.center }, _vm.customClass ], style: _vm.style, attrs: { role: "dialog", "aria-modal": "true", "aria-label": _vm.title || "dialog" } }, [ _c( "div", { staticClass: "el-dialog__header" }, [ _vm._t("title", [ _c("span", { staticClass: "el-dialog__title" }, [ _vm._v(_vm._s(_vm.title)) ]) ]), _vm.showClose ? _c( "button", { staticClass: "el-dialog__headerbtn", attrs: { type: "button", "aria-label": "Close" }, on: { click: _vm.handleClose } }, [ _c("i", { staticClass: "el-dialog__close el-icon el-icon-close" }) ] ) : _vm._e() ], 2 ), _vm.rendered ? _c( "div", { staticClass: "el-dialog__body" }, [_vm._t("default")], 2 ) : _vm._e(), _vm.$slots.footer ? _c( "div", { staticClass: "el-dialog__footer" }, [_vm._t("footer")], 2 ) : _vm._e() ] ) ] ) ] ) } var componentvue_type_template_id_60140e62_staticRenderFns = [] componentvue_type_template_id_60140e62_render._withStripped = true // CONCATENATED MODULE: ./packages/dialog/src/component.vue?vue&type=template&id=60140e62& // EXTERNAL MODULE: external "element-ui/lib/utils/popup" var popup_ = __webpack_require__(14); var popup_default = /*#__PURE__*/__webpack_require__.n(popup_); // EXTERNAL MODULE: external "element-ui/lib/mixins/migrating" var migrating_ = __webpack_require__(9); var migrating_default = /*#__PURE__*/__webpack_require__.n(migrating_); // EXTERNAL MODULE: external "element-ui/lib/mixins/emitter" var emitter_ = __webpack_require__(3); var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dialog/src/component.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var componentvue_type_script_lang_js_ = ({ name: 'ElDialog', mixins: [popup_default.a, emitter_default.a, migrating_default.a], props: { title: { type: String, default: '' }, modal: { type: Boolean, default: true }, modalAppendToBody: { type: Boolean, default: true }, appendToBody: { type: Boolean, default: false }, lockScroll: { type: Boolean, default: true }, closeOnClickModal: { type: Boolean, default: true }, closeOnPressEscape: { type: Boolean, default: true }, showClose: { type: Boolean, default: true }, width: String, fullscreen: Boolean, customClass: { type: String, default: '' }, top: { type: String, default: '15vh' }, beforeClose: Function, center: { type: Boolean, default: false }, destroyOnClose: Boolean }, data: function data() { return { closed: false, key: 0 }; }, watch: { visible: function visible(val) { var _this = this; if (val) { this.closed = false; this.$emit('open'); this.$el.addEventListener('scroll', this.updatePopper); this.$nextTick(function () { _this.$refs.dialog.scrollTop = 0; }); if (this.appendToBody) { document.body.appendChild(this.$el); } } else { this.$el.removeEventListener('scroll', this.updatePopper); if (!this.closed) this.$emit('close'); if (this.destroyOnClose) { this.$nextTick(function () { _this.key++; }); } } } }, computed: { style: function style() { var style = {}; if (!this.fullscreen) { style.marginTop = this.top; if (this.width) { style.width = this.width; } } return style; } }, methods: { getMigratingConfig: function getMigratingConfig() { return { props: { 'size': 'size is removed.' } }; }, handleWrapperClick: function handleWrapperClick() { if (!this.closeOnClickModal) return; this.handleClose(); }, handleClose: function handleClose() { if (typeof this.beforeClose === 'function') { this.beforeClose(this.hide); } else { this.hide(); } }, hide: function hide(cancel) { if (cancel !== false) { this.$emit('update:visible', false); this.$emit('close'); this.closed = true; } }, updatePopper: function updatePopper() { this.broadcast('ElSelectDropdown', 'updatePopper'); this.broadcast('ElDropdownMenu', 'updatePopper'); }, afterEnter: function afterEnter() { this.$emit('opened'); }, afterLeave: function afterLeave() { this.$emit('closed'); } }, mounted: function mounted() { if (this.visible) { this.rendered = true; this.open(); if (this.appendToBody) { document.body.appendChild(this.$el); } } }, destroyed: function destroyed() { // if appendToBody is true, remove DOM node after destroy if (this.appendToBody && this.$el && this.$el.parentNode) { this.$el.parentNode.removeChild(this.$el); } } }); // CONCATENATED MODULE: ./packages/dialog/src/component.vue?vue&type=script&lang=js& /* harmony default export */ var src_componentvue_type_script_lang_js_ = (componentvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/dialog/src/component.vue /* normalize component */ var component_component = normalizeComponent( src_componentvue_type_script_lang_js_, componentvue_type_template_id_60140e62_render, componentvue_type_template_id_60140e62_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var component_api; } component_component.options.__file = "packages/dialog/src/component.vue" /* harmony default export */ var src_component = (component_component.exports); // CONCATENATED MODULE: ./packages/dialog/index.js /* istanbul ignore next */ src_component.install = function (Vue) { Vue.component(src_component.name, src_component); }; /* harmony default export */ var dialog = (src_component); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete.vue?vue&type=template&id=152f2ee6& var autocompletevue_type_template_id_152f2ee6_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: _vm.close, expression: "close" } ], staticClass: "el-autocomplete", attrs: { "aria-haspopup": "listbox", role: "combobox", "aria-expanded": _vm.suggestionVisible, "aria-owns": _vm.id } }, [ _c( "el-input", _vm._b( { ref: "input", on: { input: _vm.handleInput, change: _vm.handleChange, focus: _vm.handleFocus, blur: _vm.handleBlur, clear: _vm.handleClear }, nativeOn: { keydown: [ function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "up", 38, $event.key, [ "Up", "ArrowUp" ]) ) { return null } $event.preventDefault() _vm.highlight(_vm.highlightedIndex - 1) }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "down", 40, $event.key, [ "Down", "ArrowDown" ]) ) { return null } $event.preventDefault() _vm.highlight(_vm.highlightedIndex + 1) }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter") ) { return null } return _vm.handleKeyEnter($event) }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "tab", 9, $event.key, "Tab") ) { return null } return _vm.close($event) } ] } }, "el-input", [_vm.$props, _vm.$attrs], false ), [ _vm.$slots.prepend ? _c("template", { slot: "prepend" }, [_vm._t("prepend")], 2) : _vm._e(), _vm.$slots.append ? _c("template", { slot: "append" }, [_vm._t("append")], 2) : _vm._e(), _vm.$slots.prefix ? _c("template", { slot: "prefix" }, [_vm._t("prefix")], 2) : _vm._e(), _vm.$slots.suffix ? _c("template", { slot: "suffix" }, [_vm._t("suffix")], 2) : _vm._e() ], 2 ), _c( "el-autocomplete-suggestions", { ref: "suggestions", class: [_vm.popperClass ? _vm.popperClass : ""], attrs: { "visible-arrow": "", "popper-options": _vm.popperOptions, "append-to-body": _vm.popperAppendToBody, placement: _vm.placement, id: _vm.id } }, _vm._l(_vm.suggestions, function(item, index) { return _c( "li", { key: index, class: { highlighted: _vm.highlightedIndex === index }, attrs: { id: _vm.id + "-item-" + index, role: "option", "aria-selected": _vm.highlightedIndex === index }, on: { click: function($event) { _vm.select(item) } } }, [ _vm._t( "default", [ _vm._v("\n " + _vm._s(item[_vm.valueKey]) + "\n ") ], { item: item } ) ], 2 ) }), 0 ) ], 1 ) } var autocompletevue_type_template_id_152f2ee6_staticRenderFns = [] autocompletevue_type_template_id_152f2ee6_render._withStripped = true // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue?vue&type=template&id=152f2ee6& // EXTERNAL MODULE: external "throttle-debounce/debounce" var debounce_ = __webpack_require__(15); var debounce_default = /*#__PURE__*/__webpack_require__.n(debounce_); // EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside" var clickoutside_ = __webpack_require__(10); var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=template&id=cd10dcf0& var autocomplete_suggestionsvue_type_template_id_cd10dcf0_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.showPopper, expression: "showPopper" } ], staticClass: "el-autocomplete-suggestion el-popper", class: { "is-loading": !_vm.parent.hideLoading && _vm.parent.loading }, style: { width: _vm.dropdownWidth }, attrs: { role: "region" } }, [ _c( "el-scrollbar", { attrs: { tag: "ul", "wrap-class": "el-autocomplete-suggestion__wrap", "view-class": "el-autocomplete-suggestion__list" } }, [ !_vm.parent.hideLoading && _vm.parent.loading ? _c("li", [_c("i", { staticClass: "el-icon-loading" })]) : _vm._t("default") ], 2 ) ], 1 ) ] ) } var autocomplete_suggestionsvue_type_template_id_cd10dcf0_staticRenderFns = [] autocomplete_suggestionsvue_type_template_id_cd10dcf0_render._withStripped = true // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=template&id=cd10dcf0& // EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper" var vue_popper_ = __webpack_require__(5); var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_); // EXTERNAL MODULE: external "element-ui/lib/scrollbar" var scrollbar_ = __webpack_require__(17); var scrollbar_default = /*#__PURE__*/__webpack_require__.n(scrollbar_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // /* harmony default export */ var autocomplete_suggestionsvue_type_script_lang_js_ = ({ components: { ElScrollbar: scrollbar_default.a }, mixins: [vue_popper_default.a, emitter_default.a], componentName: 'ElAutocompleteSuggestions', data: function data() { return { parent: this.$parent, dropdownWidth: '' }; }, props: { options: { default: function _default() { return { gpuAcceleration: false }; } }, id: String }, methods: { select: function select(item) { this.dispatch('ElAutocomplete', 'item-click', item); } }, updated: function updated() { var _this = this; this.$nextTick(function (_) { _this.popperJS && _this.updatePopper(); }); }, mounted: function mounted() { this.$parent.popperElm = this.popperElm = this.$el; this.referenceElm = this.$parent.$refs.input.$refs.input || this.$parent.$refs.input.$refs.textarea; this.referenceList = this.$el.querySelector('.el-autocomplete-suggestion__list'); this.referenceList.setAttribute('role', 'listbox'); this.referenceList.setAttribute('id', this.id); }, created: function created() { var _this2 = this; this.$on('visible', function (val, inputWidth) { _this2.dropdownWidth = inputWidth + 'px'; _this2.showPopper = val; }); } }); // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue?vue&type=script&lang=js& /* harmony default export */ var src_autocomplete_suggestionsvue_type_script_lang_js_ = (autocomplete_suggestionsvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete-suggestions.vue /* normalize component */ var autocomplete_suggestions_component = normalizeComponent( src_autocomplete_suggestionsvue_type_script_lang_js_, autocomplete_suggestionsvue_type_template_id_cd10dcf0_render, autocomplete_suggestionsvue_type_template_id_cd10dcf0_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var autocomplete_suggestions_api; } autocomplete_suggestions_component.options.__file = "packages/autocomplete/src/autocomplete-suggestions.vue" /* harmony default export */ var autocomplete_suggestions = (autocomplete_suggestions_component.exports); // EXTERNAL MODULE: external "element-ui/lib/mixins/focus" var focus_ = __webpack_require__(22); var focus_default = /*#__PURE__*/__webpack_require__.n(focus_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/autocomplete/src/autocomplete.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var autocompletevue_type_script_lang_js_ = ({ name: 'ElAutocomplete', mixins: [emitter_default.a, focus_default()('input'), migrating_default.a], inheritAttrs: false, componentName: 'ElAutocomplete', components: { ElInput: input_default.a, ElAutocompleteSuggestions: autocomplete_suggestions }, directives: { Clickoutside: clickoutside_default.a }, props: { valueKey: { type: String, default: 'value' }, popperClass: String, popperOptions: Object, placeholder: String, clearable: { type: Boolean, default: false }, disabled: Boolean, name: String, size: String, value: String, maxlength: Number, minlength: Number, autofocus: Boolean, fetchSuggestions: Function, triggerOnFocus: { type: Boolean, default: true }, customItem: String, selectWhenUnmatched: { type: Boolean, default: false }, prefixIcon: String, suffixIcon: String, label: String, debounce: { type: Number, default: 300 }, placement: { type: String, default: 'bottom-start' }, hideLoading: Boolean, popperAppendToBody: { type: Boolean, default: true }, highlightFirstItem: { type: Boolean, default: false } }, data: function data() { return { activated: false, suggestions: [], loading: false, highlightedIndex: -1, suggestionDisabled: false }; }, computed: { suggestionVisible: function suggestionVisible() { var suggestions = this.suggestions; var isValidData = Array.isArray(suggestions) && suggestions.length > 0; return (isValidData || this.loading) && this.activated; }, id: function id() { return 'el-autocomplete-' + Object(util_["generateId"])(); } }, watch: { suggestionVisible: function suggestionVisible(val) { var $input = this.getInput(); if ($input) { this.broadcast('ElAutocompleteSuggestions', 'visible', [val, $input.offsetWidth]); } } }, methods: { getMigratingConfig: function getMigratingConfig() { return { props: { 'custom-item': 'custom-item is removed, use scoped slot instead.', 'props': 'props is removed, use value-key instead.' } }; }, getData: function getData(queryString) { var _this = this; if (this.suggestionDisabled) { return; } this.loading = true; this.fetchSuggestions(queryString, function (suggestions) { _this.loading = false; if (_this.suggestionDisabled) { return; } if (Array.isArray(suggestions)) { _this.suggestions = suggestions; _this.highlightedIndex = _this.highlightFirstItem ? 0 : -1; } else { console.error('[Element Error][Autocomplete]autocomplete suggestions must be an array'); } }); }, handleInput: function handleInput(value) { this.$emit('input', value); this.suggestionDisabled = false; if (!this.triggerOnFocus && !value) { this.suggestionDisabled = true; this.suggestions = []; return; } this.debouncedGetData(value); }, handleChange: function handleChange(value) { this.$emit('change', value); }, handleFocus: function handleFocus(event) { this.activated = true; this.$emit('focus', event); if (this.triggerOnFocus) { this.debouncedGetData(this.value); } }, handleBlur: function handleBlur(event) { this.$emit('blur', event); }, handleClear: function handleClear() { this.activated = false; this.$emit('clear'); }, close: function close(e) { this.activated = false; }, handleKeyEnter: function handleKeyEnter(e) { var _this2 = this; if (this.suggestionVisible && this.highlightedIndex >= 0 && this.highlightedIndex < this.suggestions.length) { e.preventDefault(); this.select(this.suggestions[this.highlightedIndex]); } else if (this.selectWhenUnmatched) { this.$emit('select', { value: this.value }); this.$nextTick(function (_) { _this2.suggestions = []; _this2.highlightedIndex = -1; }); } }, select: function select(item) { var _this3 = this; this.$emit('input', item[this.valueKey]); this.$emit('select', item); this.$nextTick(function (_) { _this3.suggestions = []; _this3.highlightedIndex = -1; }); }, highlight: function highlight(index) { if (!this.suggestionVisible || this.loading) { return; } if (index < 0) { this.highlightedIndex = -1; return; } if (index >= this.suggestions.length) { index = this.suggestions.length - 1; } var suggestion = this.$refs.suggestions.$el.querySelector('.el-autocomplete-suggestion__wrap'); var suggestionList = suggestion.querySelectorAll('.el-autocomplete-suggestion__list li'); var highlightItem = suggestionList[index]; var scrollTop = suggestion.scrollTop; var offsetTop = highlightItem.offsetTop; if (offsetTop + highlightItem.scrollHeight > scrollTop + suggestion.clientHeight) { suggestion.scrollTop += highlightItem.scrollHeight; } if (offsetTop < scrollTop) { suggestion.scrollTop -= highlightItem.scrollHeight; } this.highlightedIndex = index; var $input = this.getInput(); $input.setAttribute('aria-activedescendant', this.id + '-item-' + this.highlightedIndex); }, getInput: function getInput() { return this.$refs.input.getInput(); } }, mounted: function mounted() { var _this4 = this; this.debouncedGetData = debounce_default()(this.debounce, this.getData); this.$on('item-click', function (item) { _this4.select(item); }); var $input = this.getInput(); $input.setAttribute('role', 'textbox'); $input.setAttribute('aria-autocomplete', 'list'); $input.setAttribute('aria-controls', 'id'); $input.setAttribute('aria-activedescendant', this.id + '-item-' + this.highlightedIndex); }, beforeDestroy: function beforeDestroy() { this.$refs.suggestions.$destroy(); } }); // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue?vue&type=script&lang=js& /* harmony default export */ var src_autocompletevue_type_script_lang_js_ = (autocompletevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/autocomplete/src/autocomplete.vue /* normalize component */ var autocomplete_component = normalizeComponent( src_autocompletevue_type_script_lang_js_, autocompletevue_type_template_id_152f2ee6_render, autocompletevue_type_template_id_152f2ee6_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var autocomplete_api; } autocomplete_component.options.__file = "packages/autocomplete/src/autocomplete.vue" /* harmony default export */ var autocomplete = (autocomplete_component.exports); // CONCATENATED MODULE: ./packages/autocomplete/index.js /* istanbul ignore next */ autocomplete.install = function (Vue) { Vue.component(autocomplete.name, autocomplete); }; /* harmony default export */ var packages_autocomplete = (autocomplete); // EXTERNAL MODULE: external "element-ui/lib/button" var button_ = __webpack_require__(12); var button_default = /*#__PURE__*/__webpack_require__.n(button_); // EXTERNAL MODULE: external "element-ui/lib/button-group" var button_group_ = __webpack_require__(29); var button_group_default = /*#__PURE__*/__webpack_require__.n(button_group_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown.vue?vue&type=script&lang=js& /* harmony default export */ var dropdownvue_type_script_lang_js_ = ({ name: 'ElDropdown', componentName: 'ElDropdown', mixins: [emitter_default.a, migrating_default.a], directives: { Clickoutside: clickoutside_default.a }, components: { ElButton: button_default.a, ElButtonGroup: button_group_default.a }, provide: function provide() { return { dropdown: this }; }, props: { trigger: { type: String, default: 'hover' }, type: String, size: { type: String, default: '' }, splitButton: Boolean, hideOnClick: { type: Boolean, default: true }, placement: { type: String, default: 'bottom-end' }, visibleArrow: { default: true }, showTimeout: { type: Number, default: 250 }, hideTimeout: { type: Number, default: 150 }, tabindex: { type: Number, default: 0 } }, data: function data() { return { timeout: null, visible: false, triggerElm: null, menuItems: null, menuItemsArray: null, dropdownElm: null, focusing: false, listId: 'dropdown-menu-' + Object(util_["generateId"])() }; }, computed: { dropdownSize: function dropdownSize() { return this.size || (this.$ELEMENT || {}).size; } }, mounted: function mounted() { this.$on('menu-item-click', this.handleMenuItemClick); }, watch: { visible: function visible(val) { this.broadcast('ElDropdownMenu', 'visible', val); this.$emit('visible-change', val); }, focusing: function focusing(val) { var selfDefine = this.$el.querySelector('.el-dropdown-selfdefine'); if (selfDefine) { // 自定义 if (val) { selfDefine.className += ' focusing'; } else { selfDefine.className = selfDefine.className.replace('focusing', ''); } } } }, methods: { getMigratingConfig: function getMigratingConfig() { return { props: { 'menu-align': 'menu-align is renamed to placement.' } }; }, show: function show() { var _this = this; if (this.triggerElm.disabled) return; clearTimeout(this.timeout); this.timeout = setTimeout(function () { _this.visible = true; }, this.trigger === 'click' ? 0 : this.showTimeout); }, hide: function hide() { var _this2 = this; if (this.triggerElm.disabled) return; this.removeTabindex(); if (this.tabindex >= 0) { this.resetTabindex(this.triggerElm); } clearTimeout(this.timeout); this.timeout = setTimeout(function () { _this2.visible = false; }, this.trigger === 'click' ? 0 : this.hideTimeout); }, handleClick: function handleClick() { if (this.triggerElm.disabled) return; if (this.visible) { this.hide(); } else { this.show(); } }, handleTriggerKeyDown: function handleTriggerKeyDown(ev) { var keyCode = ev.keyCode; if ([38, 40].indexOf(keyCode) > -1) { // up/down this.removeTabindex(); this.resetTabindex(this.menuItems[0]); this.menuItems[0].focus(); ev.preventDefault(); ev.stopPropagation(); } else if (keyCode === 13) { // space enter选中 this.handleClick(); } else if ([9, 27].indexOf(keyCode) > -1) { // tab || esc this.hide(); } }, handleItemKeyDown: function handleItemKeyDown(ev) { var keyCode = ev.keyCode; var target = ev.target; var currentIndex = this.menuItemsArray.indexOf(target); var max = this.menuItemsArray.length - 1; var nextIndex = void 0; if ([38, 40].indexOf(keyCode) > -1) { // up/down if (keyCode === 38) { // up nextIndex = currentIndex !== 0 ? currentIndex - 1 : 0; } else { // down nextIndex = currentIndex < max ? currentIndex + 1 : max; } this.removeTabindex(); this.resetTabindex(this.menuItems[nextIndex]); this.menuItems[nextIndex].focus(); ev.preventDefault(); ev.stopPropagation(); } else if (keyCode === 13) { // enter选中 this.triggerElmFocus(); target.click(); if (this.hideOnClick) { // click关闭 this.visible = false; } } else if ([9, 27].indexOf(keyCode) > -1) { // tab // esc this.hide(); this.triggerElmFocus(); } }, resetTabindex: function resetTabindex(ele) { // 下次tab时组件聚焦元素 this.removeTabindex(); ele.setAttribute('tabindex', '0'); // 下次期望的聚焦元素 }, removeTabindex: function removeTabindex() { this.triggerElm.setAttribute('tabindex', '-1'); this.menuItemsArray.forEach(function (item) { item.setAttribute('tabindex', '-1'); }); }, initAria: function initAria() { this.dropdownElm.setAttribute('id', this.listId); this.triggerElm.setAttribute('aria-haspopup', 'list'); this.triggerElm.setAttribute('aria-controls', this.listId); if (!this.splitButton) { // 自定义 this.triggerElm.setAttribute('role', 'button'); this.triggerElm.setAttribute('tabindex', this.tabindex); this.triggerElm.setAttribute('class', (this.triggerElm.getAttribute('class') || '') + ' el-dropdown-selfdefine'); // 控制 } }, initEvent: function initEvent() { var _this3 = this; var trigger = this.trigger, show = this.show, hide = this.hide, handleClick = this.handleClick, splitButton = this.splitButton, handleTriggerKeyDown = this.handleTriggerKeyDown, handleItemKeyDown = this.handleItemKeyDown; this.triggerElm = splitButton ? this.$refs.trigger.$el : this.$slots.default[0].elm; var dropdownElm = this.dropdownElm; this.triggerElm.addEventListener('keydown', handleTriggerKeyDown); // triggerElm keydown dropdownElm.addEventListener('keydown', handleItemKeyDown, true); // item keydown // 控制自定义元素的样式 if (!splitButton) { this.triggerElm.addEventListener('focus', function () { _this3.focusing = true; }); this.triggerElm.addEventListener('blur', function () { _this3.focusing = false; }); this.triggerElm.addEventListener('click', function () { _this3.focusing = false; }); } if (trigger === 'hover') { this.triggerElm.addEventListener('mouseenter', show); this.triggerElm.addEventListener('mouseleave', hide); dropdownElm.addEventListener('mouseenter', show); dropdownElm.addEventListener('mouseleave', hide); } else if (trigger === 'click') { this.triggerElm.addEventListener('click', handleClick); } }, handleMenuItemClick: function handleMenuItemClick(command, instance) { if (this.hideOnClick) { this.visible = false; } this.$emit('command', command, instance); }, triggerElmFocus: function triggerElmFocus() { this.triggerElm.focus && this.triggerElm.focus(); }, initDomOperation: function initDomOperation() { this.dropdownElm = this.popperElm; this.menuItems = this.dropdownElm.querySelectorAll("[tabindex='-1']"); this.menuItemsArray = [].slice.call(this.menuItems); this.initEvent(); this.initAria(); } }, render: function render(h) { var _this4 = this; var hide = this.hide, splitButton = this.splitButton, type = this.type, dropdownSize = this.dropdownSize; var handleMainButtonClick = function handleMainButtonClick(event) { _this4.$emit('click', event); hide(); }; var triggerElm = !splitButton ? this.$slots.default : h('el-button-group', [h( 'el-button', { attrs: { type: type, size: dropdownSize }, nativeOn: { 'click': handleMainButtonClick } }, [this.$slots.default] ), h( 'el-button', { ref: 'trigger', attrs: { type: type, size: dropdownSize }, 'class': 'el-dropdown__caret-button' }, [h('i', { 'class': 'el-dropdown__icon el-icon-arrow-down' })] )]); return h( 'div', { 'class': 'el-dropdown', directives: [{ name: 'clickoutside', value: hide }] }, [triggerElm, this.$slots.dropdown] ); } }); // CONCATENATED MODULE: ./packages/dropdown/src/dropdown.vue?vue&type=script&lang=js& /* harmony default export */ var src_dropdownvue_type_script_lang_js_ = (dropdownvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/dropdown/src/dropdown.vue var dropdown_render, dropdown_staticRenderFns /* normalize component */ var dropdown_component = normalizeComponent( src_dropdownvue_type_script_lang_js_, dropdown_render, dropdown_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var dropdown_api; } dropdown_component.options.__file = "packages/dropdown/src/dropdown.vue" /* harmony default export */ var dropdown = (dropdown_component.exports); // CONCATENATED MODULE: ./packages/dropdown/index.js /* istanbul ignore next */ dropdown.install = function (Vue) { Vue.component(dropdown.name, dropdown); }; /* harmony default export */ var packages_dropdown = (dropdown); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=0da6b714& var dropdown_menuvue_type_template_id_0da6b714_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } }, [ _c( "ul", { directives: [ { name: "show", rawName: "v-show", value: _vm.showPopper, expression: "showPopper" } ], staticClass: "el-dropdown-menu el-popper", class: [_vm.size && "el-dropdown-menu--" + _vm.size] }, [_vm._t("default")], 2 ) ] ) } var dropdown_menuvue_type_template_id_0da6b714_staticRenderFns = [] dropdown_menuvue_type_template_id_0da6b714_render._withStripped = true // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=template&id=0da6b714& // 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& // // // // // // // /* harmony default export */ var dropdown_menuvue_type_script_lang_js_ = ({ name: 'ElDropdownMenu', componentName: 'ElDropdownMenu', mixins: [vue_popper_default.a], props: { visibleArrow: { type: Boolean, default: true }, arrowOffset: { type: Number, default: 0 } }, data: function data() { return { size: this.dropdown.dropdownSize }; }, inject: ['dropdown'], created: function created() { var _this = this; this.$on('updatePopper', function () { if (_this.showPopper) _this.updatePopper(); }); this.$on('visible', function (val) { _this.showPopper = val; }); }, mounted: function mounted() { this.dropdown.popperElm = this.popperElm = this.$el; this.referenceElm = this.dropdown.$el; // compatible with 2.6 new v-slot syntax // issue link https://github.com/ElemeFE/element/issues/14345 this.dropdown.initDomOperation(); }, watch: { 'dropdown.placement': { immediate: true, handler: function handler(val) { this.currentPlacement = val; } } } }); // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue?vue&type=script&lang=js& /* harmony default export */ var src_dropdown_menuvue_type_script_lang_js_ = (dropdown_menuvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-menu.vue /* normalize component */ var dropdown_menu_component = normalizeComponent( src_dropdown_menuvue_type_script_lang_js_, dropdown_menuvue_type_template_id_0da6b714_render, dropdown_menuvue_type_template_id_0da6b714_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var dropdown_menu_api; } dropdown_menu_component.options.__file = "packages/dropdown/src/dropdown-menu.vue" /* harmony default export */ var dropdown_menu = (dropdown_menu_component.exports); // CONCATENATED MODULE: ./packages/dropdown-menu/index.js /* istanbul ignore next */ dropdown_menu.install = function (Vue) { Vue.component(dropdown_menu.name, dropdown_menu); }; /* harmony default export */ var packages_dropdown_menu = (dropdown_menu); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-item.vue?vue&type=template&id=6359102a& var dropdown_itemvue_type_template_id_6359102a_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "li", { staticClass: "el-dropdown-menu__item", class: { "is-disabled": _vm.disabled, "el-dropdown-menu__item--divided": _vm.divided }, attrs: { "aria-disabled": _vm.disabled, tabindex: _vm.disabled ? null : -1 }, on: { click: _vm.handleClick } }, [_vm.icon ? _c("i", { class: _vm.icon }) : _vm._e(), _vm._t("default")], 2 ) } var dropdown_itemvue_type_template_id_6359102a_staticRenderFns = [] dropdown_itemvue_type_template_id_6359102a_render._withStripped = true // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue?vue&type=template&id=6359102a& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/dropdown/src/dropdown-item.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // /* harmony default export */ var dropdown_itemvue_type_script_lang_js_ = ({ name: 'ElDropdownItem', mixins: [emitter_default.a], props: { command: {}, disabled: Boolean, divided: Boolean, icon: String }, methods: { handleClick: function handleClick(e) { this.dispatch('ElDropdown', 'menu-item-click', [this.command, this]); } } }); // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue?vue&type=script&lang=js& /* harmony default export */ var src_dropdown_itemvue_type_script_lang_js_ = (dropdown_itemvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/dropdown/src/dropdown-item.vue /* normalize component */ var dropdown_item_component = normalizeComponent( src_dropdown_itemvue_type_script_lang_js_, dropdown_itemvue_type_template_id_6359102a_render, dropdown_itemvue_type_template_id_6359102a_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var dropdown_item_api; } dropdown_item_component.options.__file = "packages/dropdown/src/dropdown-item.vue" /* harmony default export */ var dropdown_item = (dropdown_item_component.exports); // CONCATENATED MODULE: ./packages/dropdown-item/index.js /* istanbul ignore next */ dropdown_item.install = function (Vue) { Vue.component(dropdown_item.name, dropdown_item); }; /* harmony default export */ var packages_dropdown_item = (dropdown_item); // CONCATENATED MODULE: ./src/utils/aria-utils.js var aria = aria || {}; aria.Utils = aria.Utils || {}; /** * @desc Set focus on descendant nodes until the first focusable element is * found. * @param element * DOM node for which to find the first focusable descendant. * @returns * true if a focusable element is found and focus is set. */ aria.Utils.focusFirstDescendant = function (element) { for (var i = 0; i < element.childNodes.length; i++) { var child = element.childNodes[i]; if (aria.Utils.attemptFocus(child) || aria.Utils.focusFirstDescendant(child)) { return true; } } return false; }; /** * @desc Find the last descendant node that is focusable. * @param element * DOM node for which to find the last focusable descendant. * @returns * true if a focusable element is found and focus is set. */ aria.Utils.focusLastDescendant = function (element) { for (var i = element.childNodes.length - 1; i >= 0; i--) { var child = element.childNodes[i]; if (aria.Utils.attemptFocus(child) || aria.Utils.focusLastDescendant(child)) { return true; } } return false; }; /** * @desc Set Attempt to set focus on the current node. * @param element * The node to attempt to focus on. * @returns * true if element is focused. */ aria.Utils.attemptFocus = function (element) { if (!aria.Utils.isFocusable(element)) { return false; } aria.Utils.IgnoreUtilFocusChanges = true; try { element.focus(); } catch (e) {} aria.Utils.IgnoreUtilFocusChanges = false; return document.activeElement === element; }; aria.Utils.isFocusable = function (element) { if (element.tabIndex > 0 || element.tabIndex === 0 && element.getAttribute('tabIndex') !== null) { return true; } if (element.disabled) { return false; } switch (element.nodeName) { case 'A': return !!element.href && element.rel !== 'ignore'; case 'INPUT': return element.type !== 'hidden' && element.type !== 'file'; case 'BUTTON': case 'SELECT': case 'TEXTAREA': return true; default: return false; } }; /** * 触发一个事件 * mouseenter, mouseleave, mouseover, keyup, change, click 等 * @param {Element} elm * @param {String} name * @param {*} opts */ aria.Utils.triggerEvent = function (elm, name) { var eventName = void 0; if (/^mouse|click/.test(name)) { eventName = 'MouseEvents'; } else if (/^key/.test(name)) { eventName = 'KeyboardEvent'; } else { eventName = 'HTMLEvents'; } var evt = document.createEvent(eventName); for (var _len = arguments.length, opts = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) { opts[_key - 2] = arguments[_key]; } evt.initEvent.apply(evt, [name].concat(opts)); elm.dispatchEvent ? elm.dispatchEvent(evt) : elm.fireEvent('on' + name, evt); return elm; }; aria.Utils.keys = { tab: 9, enter: 13, space: 32, left: 37, up: 38, right: 39, down: 40, esc: 27 }; /* harmony default export */ var aria_utils = (aria.Utils); // CONCATENATED MODULE: ./src/utils/menu/aria-submenu.js var SubMenu = function SubMenu(parent, domNode) { this.domNode = domNode; this.parent = parent; this.subMenuItems = []; this.subIndex = 0; this.init(); }; SubMenu.prototype.init = function () { this.subMenuItems = this.domNode.querySelectorAll('li'); this.addListeners(); }; SubMenu.prototype.gotoSubIndex = function (idx) { if (idx === this.subMenuItems.length) { idx = 0; } else if (idx < 0) { idx = this.subMenuItems.length - 1; } this.subMenuItems[idx].focus(); this.subIndex = idx; }; SubMenu.prototype.addListeners = function () { var _this = this; var keys = aria_utils.keys; var parentNode = this.parent.domNode; Array.prototype.forEach.call(this.subMenuItems, function (el) { el.addEventListener('keydown', function (event) { var prevDef = false; switch (event.keyCode) { case keys.down: _this.gotoSubIndex(_this.subIndex + 1); prevDef = true; break; case keys.up: _this.gotoSubIndex(_this.subIndex - 1); prevDef = true; break; case keys.tab: aria_utils.triggerEvent(parentNode, 'mouseleave'); break; case keys.enter: case keys.space: prevDef = true; event.currentTarget.click(); break; } if (prevDef) { event.preventDefault(); event.stopPropagation(); } return false; }); }); }; /* harmony default export */ var aria_submenu = (SubMenu); // CONCATENATED MODULE: ./src/utils/menu/aria-menuitem.js var MenuItem = function MenuItem(domNode) { this.domNode = domNode; this.submenu = null; this.init(); }; MenuItem.prototype.init = function () { this.domNode.setAttribute('tabindex', '0'); var menuChild = this.domNode.querySelector('.el-menu'); if (menuChild) { this.submenu = new aria_submenu(this, menuChild); } this.addListeners(); }; MenuItem.prototype.addListeners = function () { var _this = this; var keys = aria_utils.keys; this.domNode.addEventListener('keydown', function (event) { var prevDef = false; switch (event.keyCode) { case keys.down: aria_utils.triggerEvent(event.currentTarget, 'mouseenter'); _this.submenu && _this.submenu.gotoSubIndex(0); prevDef = true; break; case keys.up: aria_utils.triggerEvent(event.currentTarget, 'mouseenter'); _this.submenu && _this.submenu.gotoSubIndex(_this.submenu.subMenuItems.length - 1); prevDef = true; break; case keys.tab: aria_utils.triggerEvent(event.currentTarget, 'mouseleave'); break; case keys.enter: case keys.space: prevDef = true; event.currentTarget.click(); break; } if (prevDef) { event.preventDefault(); } }); }; /* harmony default export */ var aria_menuitem = (MenuItem); // CONCATENATED MODULE: ./src/utils/menu/aria-menubar.js var Menu = function Menu(domNode) { this.domNode = domNode; this.init(); }; Menu.prototype.init = function () { var menuChildren = this.domNode.childNodes; [].filter.call(menuChildren, function (child) { return child.nodeType === 1; }).forEach(function (child) { new aria_menuitem(child); // eslint-disable-line }); }; /* harmony default export */ var aria_menubar = (Menu); // EXTERNAL MODULE: external "element-ui/lib/utils/dom" var dom_ = __webpack_require__(1); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu.vue?vue&type=script&lang=js& /* harmony default export */ var menuvue_type_script_lang_js_ = ({ name: 'ElMenu', render: function render(h) { var component = h( 'ul', { attrs: { role: 'menubar' }, key: +this.collapse, style: { backgroundColor: this.backgroundColor || '' }, 'class': { 'el-menu--horizontal': this.mode === 'horizontal', 'el-menu--collapse': this.collapse, "el-menu": true } }, [this.$slots.default] ); if (this.collapseTransition) { return h('el-menu-collapse-transition', [component]); } else { return component; } }, componentName: 'ElMenu', mixins: [emitter_default.a, migrating_default.a], provide: function provide() { return { rootMenu: this }; }, components: { 'el-menu-collapse-transition': { functional: true, render: function render(createElement, context) { var data = { props: { mode: 'out-in' }, on: { beforeEnter: function beforeEnter(el) { el.style.opacity = 0.2; }, enter: function enter(el) { Object(dom_["addClass"])(el, 'el-opacity-transition'); el.style.opacity = 1; }, afterEnter: function afterEnter(el) { Object(dom_["removeClass"])(el, 'el-opacity-transition'); el.style.opacity = ''; }, beforeLeave: function beforeLeave(el) { if (!el.dataset) el.dataset = {}; if (Object(dom_["hasClass"])(el, 'el-menu--collapse')) { Object(dom_["removeClass"])(el, 'el-menu--collapse'); el.dataset.oldOverflow = el.style.overflow; el.dataset.scrollWidth = el.clientWidth; Object(dom_["addClass"])(el, 'el-menu--collapse'); } else { Object(dom_["addClass"])(el, 'el-menu--collapse'); el.dataset.oldOverflow = el.style.overflow; el.dataset.scrollWidth = el.clientWidth; Object(dom_["removeClass"])(el, 'el-menu--collapse'); } el.style.width = el.scrollWidth + 'px'; el.style.overflow = 'hidden'; }, leave: function leave(el) { Object(dom_["addClass"])(el, 'horizontal-collapse-transition'); el.style.width = el.dataset.scrollWidth + 'px'; } } }; return createElement('transition', data, context.children); } } }, props: { mode: { type: String, default: 'vertical' }, defaultActive: { type: String, default: '' }, defaultOpeneds: Array, uniqueOpened: Boolean, router: Boolean, menuTrigger: { type: String, default: 'hover' }, collapse: Boolean, backgroundColor: String, textColor: String, activeTextColor: String, collapseTransition: { type: Boolean, default: true } }, data: function data() { return { activeIndex: this.defaultActive, openedMenus: this.defaultOpeneds && !this.collapse ? this.defaultOpeneds.slice(0) : [], items: {}, submenus: {} }; }, computed: { hoverBackground: function hoverBackground() { return this.backgroundColor ? this.mixColor(this.backgroundColor, 0.2) : ''; }, isMenuPopup: function isMenuPopup() { return this.mode === 'horizontal' || this.mode === 'vertical' && this.collapse; } }, watch: { defaultActive: function defaultActive(value) { if (!this.items[value]) { this.activeIndex = null; } this.updateActiveIndex(value); }, defaultOpeneds: function defaultOpeneds(value) { if (!this.collapse) { this.openedMenus = value; } }, collapse: function collapse(value) { if (value) this.openedMenus = []; this.broadcast('ElSubmenu', 'toggle-collapse', value); } }, methods: { updateActiveIndex: function updateActiveIndex(val) { var item = this.items[val] || this.items[this.activeIndex] || this.items[this.defaultActive]; if (item) { this.activeIndex = item.index; this.initOpenedMenu(); } else { this.activeIndex = null; } }, getMigratingConfig: function getMigratingConfig() { return { props: { 'theme': 'theme is removed.' } }; }, getColorChannels: function getColorChannels(color) { color = color.replace('#', ''); if (/^[0-9a-fA-F]{3}$/.test(color)) { color = color.split(''); for (var i = 2; i >= 0; i--) { color.splice(i, 0, color[i]); } color = color.join(''); } if (/^[0-9a-fA-F]{6}$/.test(color)) { return { red: parseInt(color.slice(0, 2), 16), green: parseInt(color.slice(2, 4), 16), blue: parseInt(color.slice(4, 6), 16) }; } else { return { red: 255, green: 255, blue: 255 }; } }, mixColor: function mixColor(color, percent) { var _getColorChannels = this.getColorChannels(color), red = _getColorChannels.red, green = _getColorChannels.green, blue = _getColorChannels.blue; if (percent > 0) { // shade given color red *= 1 - percent; green *= 1 - percent; blue *= 1 - percent; } else { // tint given color red += (255 - red) * percent; green += (255 - green) * percent; blue += (255 - blue) * percent; } return 'rgb(' + Math.round(red) + ', ' + Math.round(green) + ', ' + Math.round(blue) + ')'; }, addItem: function addItem(item) { this.$set(this.items, item.index, item); }, removeItem: function removeItem(item) { delete this.items[item.index]; }, addSubmenu: function addSubmenu(item) { this.$set(this.submenus, item.index, item); }, removeSubmenu: function removeSubmenu(item) { delete this.submenus[item.index]; }, openMenu: function openMenu(index, indexPath) { var openedMenus = this.openedMenus; if (openedMenus.indexOf(index) !== -1) return; // 将不在该菜单路径下的其余菜单收起 // collapse all menu that are not under current menu item if (this.uniqueOpened) { this.openedMenus = openedMenus.filter(function (index) { return indexPath.indexOf(index) !== -1; }); } this.openedMenus.push(index); }, closeMenu: function closeMenu(index) { var i = this.openedMenus.indexOf(index); if (i !== -1) { this.openedMenus.splice(i, 1); } }, handleSubmenuClick: function handleSubmenuClick(submenu) { var index = submenu.index, indexPath = submenu.indexPath; var isOpened = this.openedMenus.indexOf(index) !== -1; if (isOpened) { this.closeMenu(index); this.$emit('close', index, indexPath); } else { this.openMenu(index, indexPath); this.$emit('open', index, indexPath); } }, handleItemClick: function handleItemClick(item) { var _this = this; var index = item.index, indexPath = item.indexPath; var oldActiveIndex = this.activeIndex; var hasIndex = item.index !== null; if (hasIndex) { this.activeIndex = item.index; } this.$emit('select', index, indexPath, item); if (this.mode === 'horizontal' || this.collapse) { this.openedMenus = []; } if (this.router && hasIndex) { this.routeToItem(item, function (error) { _this.activeIndex = oldActiveIndex; if (error) { // vue-router 3.1.0+ push/replace cause NavigationDuplicated error // https://github.com/ElemeFE/element/issues/17044 if (error.name === 'NavigationDuplicated') return; console.error(error); } }); } }, // 初始化展开菜单 // initialize opened menu initOpenedMenu: function initOpenedMenu() { var _this2 = this; var index = this.activeIndex; var activeItem = this.items[index]; if (!activeItem || this.mode === 'horizontal' || this.collapse) return; var indexPath = activeItem.indexPath; // 展开该菜单项的路径上所有子菜单 // expand all submenus of the menu item indexPath.forEach(function (index) { var submenu = _this2.submenus[index]; submenu && _this2.openMenu(index, submenu.indexPath); }); }, routeToItem: function routeToItem(item, onError) { var route = item.route || item.index; try { this.$router.push(route, function () {}, onError); } catch (e) { console.error(e); } }, open: function open(index) { var _this3 = this; var indexPath = this.submenus[index.toString()].indexPath; indexPath.forEach(function (i) { return _this3.openMenu(i, indexPath); }); }, close: function close(index) { this.closeMenu(index); } }, mounted: function mounted() { this.initOpenedMenu(); this.$on('item-click', this.handleItemClick); this.$on('submenu-click', this.handleSubmenuClick); if (this.mode === 'horizontal') { new aria_menubar(this.$el); // eslint-disable-line } this.$watch('items', this.updateActiveIndex); } }); // CONCATENATED MODULE: ./packages/menu/src/menu.vue?vue&type=script&lang=js& /* harmony default export */ var src_menuvue_type_script_lang_js_ = (menuvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/menu/src/menu.vue var menu_render, menu_staticRenderFns /* normalize component */ var menu_component = normalizeComponent( src_menuvue_type_script_lang_js_, menu_render, menu_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var menu_api; } menu_component.options.__file = "packages/menu/src/menu.vue" /* harmony default export */ var src_menu = (menu_component.exports); // CONCATENATED MODULE: ./packages/menu/index.js /* istanbul ignore next */ src_menu.install = function (Vue) { Vue.component(src_menu.name, src_menu); }; /* harmony default export */ var packages_menu = (src_menu); // EXTERNAL MODULE: external "element-ui/lib/transitions/collapse-transition" var collapse_transition_ = __webpack_require__(21); var collapse_transition_default = /*#__PURE__*/__webpack_require__.n(collapse_transition_); // CONCATENATED MODULE: ./packages/menu/src/menu-mixin.js /* harmony default export */ var menu_mixin = ({ inject: ['rootMenu'], computed: { indexPath: function indexPath() { var path = [this.index]; var parent = this.$parent; while (parent.$options.componentName !== 'ElMenu') { if (parent.index) { path.unshift(parent.index); } parent = parent.$parent; } return path; }, parentMenu: function parentMenu() { var parent = this.$parent; while (parent && ['ElMenu', 'ElSubmenu'].indexOf(parent.$options.componentName) === -1) { parent = parent.$parent; } return parent; }, paddingStyle: function paddingStyle() { if (this.rootMenu.mode !== 'vertical') return {}; var padding = 20; var parent = this.$parent; if (this.rootMenu.collapse) { padding = 20; } else { while (parent && parent.$options.componentName !== 'ElMenu') { if (parent.$options.componentName === 'ElSubmenu') { padding += 20; } parent = parent.$parent; } } return { paddingLeft: padding + 'px' }; } } }); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/submenu.vue?vue&type=script&lang=js& var poperMixins = { props: { transformOrigin: { type: [Boolean, String], default: false }, offset: vue_popper_default.a.props.offset, boundariesPadding: vue_popper_default.a.props.boundariesPadding, popperOptions: vue_popper_default.a.props.popperOptions }, data: vue_popper_default.a.data, methods: vue_popper_default.a.methods, beforeDestroy: vue_popper_default.a.beforeDestroy, deactivated: vue_popper_default.a.deactivated }; /* harmony default export */ var submenuvue_type_script_lang_js_ = ({ name: 'ElSubmenu', componentName: 'ElSubmenu', mixins: [menu_mixin, emitter_default.a, poperMixins], components: { ElCollapseTransition: collapse_transition_default.a }, props: { index: { type: String, required: true }, showTimeout: { type: Number, default: 300 }, hideTimeout: { type: Number, default: 300 }, popperClass: String, disabled: Boolean, popperAppendToBody: { type: Boolean, default: undefined } }, data: function data() { return { popperJS: null, timeout: null, items: {}, submenus: {}, mouseInChild: false }; }, watch: { opened: function opened(val) { var _this = this; if (this.isMenuPopup) { this.$nextTick(function (_) { _this.updatePopper(); }); } } }, computed: { // popper option appendToBody: function appendToBody() { return this.popperAppendToBody === undefined ? this.isFirstLevel : this.popperAppendToBody; }, menuTransitionName: function menuTransitionName() { return this.rootMenu.collapse ? 'el-zoom-in-left' : 'el-zoom-in-top'; }, opened: function opened() { return this.rootMenu.openedMenus.indexOf(this.index) > -1; }, active: function active() { var isActive = false; var submenus = this.submenus; var items = this.items; Object.keys(items).forEach(function (index) { if (items[index].active) { isActive = true; } }); Object.keys(submenus).forEach(function (index) { if (submenus[index].active) { isActive = true; } }); return isActive; }, hoverBackground: function hoverBackground() { return this.rootMenu.hoverBackground; }, backgroundColor: function backgroundColor() { return this.rootMenu.backgroundColor || ''; }, activeTextColor: function activeTextColor() { return this.rootMenu.activeTextColor || ''; }, textColor: function textColor() { return this.rootMenu.textColor || ''; }, mode: function mode() { return this.rootMenu.mode; }, isMenuPopup: function isMenuPopup() { return this.rootMenu.isMenuPopup; }, titleStyle: function titleStyle() { if (this.mode !== 'horizontal') { return { color: this.textColor }; } return { borderBottomColor: this.active ? this.rootMenu.activeTextColor ? this.activeTextColor : '' : 'transparent', color: this.active ? this.activeTextColor : this.textColor }; }, isFirstLevel: function isFirstLevel() { var isFirstLevel = true; var parent = this.$parent; while (parent && parent !== this.rootMenu) { if (['ElSubmenu', 'ElMenuItemGroup'].indexOf(parent.$options.componentName) > -1) { isFirstLevel = false; break; } else { parent = parent.$parent; } } return isFirstLevel; } }, methods: { handleCollapseToggle: function handleCollapseToggle(value) { if (value) { this.initPopper(); } else { this.doDestroy(); } }, addItem: function addItem(item) { this.$set(this.items, item.index, item); }, removeItem: function removeItem(item) { delete this.items[item.index]; }, addSubmenu: function addSubmenu(item) { this.$set(this.submenus, item.index, item); }, removeSubmenu: function removeSubmenu(item) { delete this.submenus[item.index]; }, handleClick: function handleClick() { var rootMenu = this.rootMenu, disabled = this.disabled; if (rootMenu.menuTrigger === 'hover' && rootMenu.mode === 'horizontal' || rootMenu.collapse && rootMenu.mode === 'vertical' || disabled) { return; } this.dispatch('ElMenu', 'submenu-click', this); }, handleMouseenter: function handleMouseenter(event) { var _this2 = this; var showTimeout = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.showTimeout; if (!('ActiveXObject' in window) && event.type === 'focus' && !event.relatedTarget) { return; } var rootMenu = this.rootMenu, disabled = this.disabled; if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical' || disabled) { return; } this.dispatch('ElSubmenu', 'mouse-enter-child'); clearTimeout(this.timeout); this.timeout = setTimeout(function () { _this2.rootMenu.openMenu(_this2.index, _this2.indexPath); }, showTimeout); if (this.appendToBody) { this.$parent.$el.dispatchEvent(new MouseEvent('mouseenter')); } }, handleMouseleave: function handleMouseleave() { var _this3 = this; var deepDispatch = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; var rootMenu = this.rootMenu; if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical') { return; } this.dispatch('ElSubmenu', 'mouse-leave-child'); clearTimeout(this.timeout); this.timeout = setTimeout(function () { !_this3.mouseInChild && _this3.rootMenu.closeMenu(_this3.index); }, this.hideTimeout); if (this.appendToBody && deepDispatch) { if (this.$parent.$options.name === 'ElSubmenu') { this.$parent.handleMouseleave(true); } } }, handleTitleMouseenter: function handleTitleMouseenter() { if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return; var title = this.$refs['submenu-title']; title && (title.style.backgroundColor = this.rootMenu.hoverBackground); }, handleTitleMouseleave: function handleTitleMouseleave() { if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return; var title = this.$refs['submenu-title']; title && (title.style.backgroundColor = this.rootMenu.backgroundColor || ''); }, updatePlacement: function updatePlacement() { this.currentPlacement = this.mode === 'horizontal' && this.isFirstLevel ? 'bottom-start' : 'right-start'; }, initPopper: function initPopper() { this.referenceElm = this.$el; this.popperElm = this.$refs.menu; this.updatePlacement(); } }, created: function created() { var _this4 = this; this.$on('toggle-collapse', this.handleCollapseToggle); this.$on('mouse-enter-child', function () { _this4.mouseInChild = true; clearTimeout(_this4.timeout); }); this.$on('mouse-leave-child', function () { _this4.mouseInChild = false; clearTimeout(_this4.timeout); }); }, mounted: function mounted() { this.parentMenu.addSubmenu(this); this.rootMenu.addSubmenu(this); this.initPopper(); }, beforeDestroy: function beforeDestroy() { this.parentMenu.removeSubmenu(this); this.rootMenu.removeSubmenu(this); }, render: function render(h) { var _this5 = this; var active = this.active, opened = this.opened, paddingStyle = this.paddingStyle, titleStyle = this.titleStyle, backgroundColor = this.backgroundColor, rootMenu = this.rootMenu, currentPlacement = this.currentPlacement, menuTransitionName = this.menuTransitionName, mode = this.mode, disabled = this.disabled, popperClass = this.popperClass, $slots = this.$slots, isFirstLevel = this.isFirstLevel; var popupMenu = h( 'transition', { attrs: { name: menuTransitionName } }, [h( 'div', { ref: 'menu', directives: [{ name: 'show', value: opened }], 'class': ['el-menu--' + mode, popperClass], on: { 'mouseenter': function mouseenter($event) { return _this5.handleMouseenter($event, 100); }, 'mouseleave': function mouseleave() { return _this5.handleMouseleave(true); }, 'focus': function focus($event) { return _this5.handleMouseenter($event, 100); } } }, [h( 'ul', { attrs: { role: 'menu' }, 'class': ['el-menu el-menu--popup', 'el-menu--popup-' + currentPlacement], style: { backgroundColor: rootMenu.backgroundColor || '' } }, [$slots.default] )] )] ); var inlineMenu = h('el-collapse-transition', [h( 'ul', { attrs: { role: 'menu' }, 'class': 'el-menu el-menu--inline', directives: [{ name: 'show', value: opened }], style: { backgroundColor: rootMenu.backgroundColor || '' } }, [$slots.default] )]); var submenuTitleIcon = rootMenu.mode === 'horizontal' && isFirstLevel || rootMenu.mode === 'vertical' && !rootMenu.collapse ? 'el-icon-arrow-down' : 'el-icon-arrow-right'; return h( 'li', { 'class': { 'el-submenu': true, 'is-active': active, 'is-opened': opened, 'is-disabled': disabled }, attrs: { role: 'menuitem', 'aria-haspopup': 'true', 'aria-expanded': opened }, on: { 'mouseenter': this.handleMouseenter, 'mouseleave': function mouseleave() { return _this5.handleMouseleave(false); }, 'focus': this.handleMouseenter } }, [h( 'div', { 'class': 'el-submenu__title', ref: 'submenu-title', on: { 'click': this.handleClick, 'mouseenter': this.handleTitleMouseenter, 'mouseleave': this.handleTitleMouseleave }, style: [paddingStyle, titleStyle, { backgroundColor: backgroundColor }] }, [$slots.title, h('i', { 'class': ['el-submenu__icon-arrow', submenuTitleIcon] })] ), this.isMenuPopup ? popupMenu : inlineMenu] ); } }); // CONCATENATED MODULE: ./packages/menu/src/submenu.vue?vue&type=script&lang=js& /* harmony default export */ var src_submenuvue_type_script_lang_js_ = (submenuvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/menu/src/submenu.vue var submenu_render, submenu_staticRenderFns /* normalize component */ var submenu_component = normalizeComponent( src_submenuvue_type_script_lang_js_, submenu_render, submenu_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var submenu_api; } submenu_component.options.__file = "packages/menu/src/submenu.vue" /* harmony default export */ var submenu = (submenu_component.exports); // CONCATENATED MODULE: ./packages/submenu/index.js /* istanbul ignore next */ submenu.install = function (Vue) { Vue.component(submenu.name, submenu); }; /* harmony default export */ var packages_submenu = (submenu); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item.vue?vue&type=template&id=2a5dbfea& var menu_itemvue_type_template_id_2a5dbfea_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "li", { staticClass: "el-menu-item", class: { "is-active": _vm.active, "is-disabled": _vm.disabled }, style: [ _vm.paddingStyle, _vm.itemStyle, { backgroundColor: _vm.backgroundColor } ], attrs: { role: "menuitem", tabindex: "-1" }, on: { click: _vm.handleClick, mouseenter: _vm.onMouseEnter, focus: _vm.onMouseEnter, blur: _vm.onMouseLeave, mouseleave: _vm.onMouseLeave } }, [ _vm.parentMenu.$options.componentName === "ElMenu" && _vm.rootMenu.collapse && _vm.$slots.title ? _c("el-tooltip", { attrs: { effect: "dark", placement: "right" } }, [ _c( "div", { attrs: { slot: "content" }, slot: "content" }, [_vm._t("title")], 2 ), _c( "div", { staticStyle: { position: "absolute", left: "0", top: "0", height: "100%", width: "100%", display: "inline-block", "box-sizing": "border-box", padding: "0 20px" } }, [_vm._t("default")], 2 ) ]) : [_vm._t("default"), _vm._t("title")] ], 2 ) } var menu_itemvue_type_template_id_2a5dbfea_staticRenderFns = [] menu_itemvue_type_template_id_2a5dbfea_render._withStripped = true // CONCATENATED MODULE: ./packages/menu/src/menu-item.vue?vue&type=template&id=2a5dbfea& // EXTERNAL MODULE: external "element-ui/lib/tooltip" var tooltip_ = __webpack_require__(26); var tooltip_default = /*#__PURE__*/__webpack_require__.n(tooltip_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var menu_itemvue_type_script_lang_js_ = ({ name: 'ElMenuItem', componentName: 'ElMenuItem', mixins: [menu_mixin, emitter_default.a], components: { ElTooltip: tooltip_default.a }, props: { index: { default: null, validator: function validator(val) { return typeof val === 'string' || val === null; } }, route: [String, Object], disabled: Boolean }, computed: { active: function active() { return this.index === this.rootMenu.activeIndex; }, hoverBackground: function hoverBackground() { return this.rootMenu.hoverBackground; }, backgroundColor: function backgroundColor() { return this.rootMenu.backgroundColor || ''; }, activeTextColor: function activeTextColor() { return this.rootMenu.activeTextColor || ''; }, textColor: function textColor() { return this.rootMenu.textColor || ''; }, mode: function mode() { return this.rootMenu.mode; }, itemStyle: function itemStyle() { var style = { color: this.active ? this.activeTextColor : this.textColor }; if (this.mode === 'horizontal' && !this.isNested) { style.borderBottomColor = this.active ? this.rootMenu.activeTextColor ? this.activeTextColor : '' : 'transparent'; } return style; }, isNested: function isNested() { return this.parentMenu !== this.rootMenu; } }, methods: { onMouseEnter: function onMouseEnter() { if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return; this.$el.style.backgroundColor = this.hoverBackground; }, onMouseLeave: function onMouseLeave() { if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return; this.$el.style.backgroundColor = this.backgroundColor; }, handleClick: function handleClick() { if (!this.disabled) { this.dispatch('ElMenu', 'item-click', this); this.$emit('click', this); } } }, mounted: function mounted() { this.parentMenu.addItem(this); this.rootMenu.addItem(this); }, beforeDestroy: function beforeDestroy() { this.parentMenu.removeItem(this); this.rootMenu.removeItem(this); } }); // CONCATENATED MODULE: ./packages/menu/src/menu-item.vue?vue&type=script&lang=js& /* harmony default export */ var src_menu_itemvue_type_script_lang_js_ = (menu_itemvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/menu/src/menu-item.vue /* normalize component */ var menu_item_component = normalizeComponent( src_menu_itemvue_type_script_lang_js_, menu_itemvue_type_template_id_2a5dbfea_render, menu_itemvue_type_template_id_2a5dbfea_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var menu_item_api; } menu_item_component.options.__file = "packages/menu/src/menu-item.vue" /* harmony default export */ var menu_item = (menu_item_component.exports); // CONCATENATED MODULE: ./packages/menu-item/index.js /* istanbul ignore next */ menu_item.install = function (Vue) { Vue.component(menu_item.name, menu_item); }; /* harmony default export */ var packages_menu_item = (menu_item); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item-group.vue?vue&type=template&id=543b7bdc& var menu_item_groupvue_type_template_id_543b7bdc_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("li", { staticClass: "el-menu-item-group" }, [ _c( "div", { staticClass: "el-menu-item-group__title", style: { paddingLeft: _vm.levelPadding + "px" } }, [!_vm.$slots.title ? [_vm._v(_vm._s(_vm.title))] : _vm._t("title")], 2 ), _c("ul", [_vm._t("default")], 2) ]) } var menu_item_groupvue_type_template_id_543b7bdc_staticRenderFns = [] menu_item_groupvue_type_template_id_543b7bdc_render._withStripped = true // CONCATENATED MODULE: ./packages/menu/src/menu-item-group.vue?vue&type=template&id=543b7bdc& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/menu-item-group.vue?vue&type=script&lang=js& // // // // // // // // // // // /* harmony default export */ var menu_item_groupvue_type_script_lang_js_ = ({ name: 'ElMenuItemGroup', componentName: 'ElMenuItemGroup', inject: ['rootMenu'], props: { title: { type: String } }, data: function data() { return { paddingLeft: 20 }; }, computed: { levelPadding: function levelPadding() { var padding = 20; var parent = this.$parent; if (this.rootMenu.collapse) return 20; while (parent && parent.$options.componentName !== 'ElMenu') { if (parent.$options.componentName === 'ElSubmenu') { padding += 20; } parent = parent.$parent; } return padding; } } }); // CONCATENATED MODULE: ./packages/menu/src/menu-item-group.vue?vue&type=script&lang=js& /* harmony default export */ var src_menu_item_groupvue_type_script_lang_js_ = (menu_item_groupvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/menu/src/menu-item-group.vue /* normalize component */ var menu_item_group_component = normalizeComponent( src_menu_item_groupvue_type_script_lang_js_, menu_item_groupvue_type_template_id_543b7bdc_render, menu_item_groupvue_type_template_id_543b7bdc_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var menu_item_group_api; } menu_item_group_component.options.__file = "packages/menu/src/menu-item-group.vue" /* harmony default export */ var menu_item_group = (menu_item_group_component.exports); // CONCATENATED MODULE: ./packages/menu-item-group/index.js /* istanbul ignore next */ menu_item_group.install = function (Vue) { Vue.component(menu_item_group.name, menu_item_group); }; /* harmony default export */ var packages_menu_item_group = (menu_item_group); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/input/src/input.vue?vue&type=template&id=343dd774& var inputvue_type_template_id_343dd774_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { class: [ _vm.type === "textarea" ? "el-textarea" : "el-input", _vm.inputSize ? "el-input--" + _vm.inputSize : "", { "is-disabled": _vm.inputDisabled, "is-exceed": _vm.inputExceed, "el-input-group": _vm.$slots.prepend || _vm.$slots.append, "el-input-group--append": _vm.$slots.append, "el-input-group--prepend": _vm.$slots.prepend, "el-input--prefix": _vm.$slots.prefix || _vm.prefixIcon, "el-input--suffix": _vm.$slots.suffix || _vm.suffixIcon || _vm.clearable || _vm.showPassword } ], on: { mouseenter: function($event) { _vm.hovering = true }, mouseleave: function($event) { _vm.hovering = false } } }, [ _vm.type !== "textarea" ? [ _vm.$slots.prepend ? _c( "div", { staticClass: "el-input-group__prepend" }, [_vm._t("prepend")], 2 ) : _vm._e(), _vm.type !== "textarea" ? _c( "input", _vm._b( { ref: "input", staticClass: "el-input__inner", attrs: { tabindex: _vm.tabindex, type: _vm.showPassword ? _vm.passwordVisible ? "text" : "password" : _vm.type, disabled: _vm.inputDisabled, readonly: _vm.readonly, autocomplete: _vm.autoComplete || _vm.autocomplete, "aria-label": _vm.label }, on: { compositionstart: _vm.handleCompositionStart, compositionupdate: _vm.handleCompositionUpdate, compositionend: _vm.handleCompositionEnd, input: _vm.handleInput, focus: _vm.handleFocus, blur: _vm.handleBlur, change: _vm.handleChange } }, "input", _vm.$attrs, false ) ) : _vm._e(), _vm.$slots.prefix || _vm.prefixIcon ? _c( "span", { staticClass: "el-input__prefix" }, [ _vm._t("prefix"), _vm.prefixIcon ? _c("i", { staticClass: "el-input__icon", class: _vm.prefixIcon }) : _vm._e() ], 2 ) : _vm._e(), _vm.getSuffixVisible() ? _c("span", { staticClass: "el-input__suffix" }, [ _c( "span", { staticClass: "el-input__suffix-inner" }, [ !_vm.showClear || !_vm.showPwdVisible || !_vm.isWordLimitVisible ? [ _vm._t("suffix"), _vm.suffixIcon ? _c("i", { staticClass: "el-input__icon", class: _vm.suffixIcon }) : _vm._e() ] : _vm._e(), _vm.showClear ? _c("i", { staticClass: "el-input__icon el-icon-circle-close el-input__clear", on: { mousedown: function($event) { $event.preventDefault() }, click: _vm.clear } }) : _vm._e(), _vm.showPwdVisible ? _c("i", { staticClass: "el-input__icon el-icon-view el-input__clear", on: { click: _vm.handlePasswordVisible } }) : _vm._e(), _vm.isWordLimitVisible ? _c("span", { staticClass: "el-input__count" }, [ _c( "span", { staticClass: "el-input__count-inner" }, [ _vm._v( "\n " + _vm._s(_vm.textLength) + "/" + _vm._s(_vm.upperLimit) + "\n " ) ] ) ]) : _vm._e() ], 2 ), _vm.validateState ? _c("i", { staticClass: "el-input__icon", class: ["el-input__validateIcon", _vm.validateIcon] }) : _vm._e() ]) : _vm._e(), _vm.$slots.append ? _c( "div", { staticClass: "el-input-group__append" }, [_vm._t("append")], 2 ) : _vm._e() ] : _c( "textarea", _vm._b( { ref: "textarea", staticClass: "el-textarea__inner", style: _vm.textareaStyle, attrs: { tabindex: _vm.tabindex, disabled: _vm.inputDisabled, readonly: _vm.readonly, autocomplete: _vm.autoComplete || _vm.autocomplete, "aria-label": _vm.label }, on: { compositionstart: _vm.handleCompositionStart, compositionupdate: _vm.handleCompositionUpdate, compositionend: _vm.handleCompositionEnd, input: _vm.handleInput, focus: _vm.handleFocus, blur: _vm.handleBlur, change: _vm.handleChange } }, "textarea", _vm.$attrs, false ) ), _vm.isWordLimitVisible && _vm.type === "textarea" ? _c("span", { staticClass: "el-input__count" }, [ _vm._v(_vm._s(_vm.textLength) + "/" + _vm._s(_vm.upperLimit)) ]) : _vm._e() ], 2 ) } var inputvue_type_template_id_343dd774_staticRenderFns = [] inputvue_type_template_id_343dd774_render._withStripped = true // CONCATENATED MODULE: ./packages/input/src/input.vue?vue&type=template&id=343dd774& // CONCATENATED MODULE: ./packages/input/src/calcTextareaHeight.js var hiddenTextarea = void 0; var HIDDEN_STYLE = '\n height:0 !important;\n visibility:hidden !important;\n overflow:hidden !important;\n position:absolute !important;\n z-index:-1000 !important;\n top:0 !important;\n right:0 !important\n'; var CONTEXT_STYLE = ['letter-spacing', 'line-height', 'padding-top', 'padding-bottom', 'font-family', 'font-weight', 'font-size', 'text-rendering', 'text-transform', 'width', 'text-indent', 'padding-left', 'padding-right', 'border-width', 'box-sizing']; function calculateNodeStyling(targetElement) { var style = window.getComputedStyle(targetElement); var boxSizing = style.getPropertyValue('box-sizing'); var paddingSize = parseFloat(style.getPropertyValue('padding-bottom')) + parseFloat(style.getPropertyValue('padding-top')); var borderSize = parseFloat(style.getPropertyValue('border-bottom-width')) + parseFloat(style.getPropertyValue('border-top-width')); var contextStyle = CONTEXT_STYLE.map(function (name) { return name + ':' + style.getPropertyValue(name); }).join(';'); return { contextStyle: contextStyle, paddingSize: paddingSize, borderSize: borderSize, boxSizing: boxSizing }; } function calcTextareaHeight(targetElement) { var minRows = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; var maxRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; if (!hiddenTextarea) { hiddenTextarea = document.createElement('textarea'); document.body.appendChild(hiddenTextarea); } var _calculateNodeStyling = calculateNodeStyling(targetElement), paddingSize = _calculateNodeStyling.paddingSize, borderSize = _calculateNodeStyling.borderSize, boxSizing = _calculateNodeStyling.boxSizing, contextStyle = _calculateNodeStyling.contextStyle; hiddenTextarea.setAttribute('style', contextStyle + ';' + HIDDEN_STYLE); hiddenTextarea.value = targetElement.value || targetElement.placeholder || ''; var height = hiddenTextarea.scrollHeight; var result = {}; if (boxSizing === 'border-box') { height = height + borderSize; } else if (boxSizing === 'content-box') { height = height - paddingSize; } hiddenTextarea.value = ''; var singleRowHeight = hiddenTextarea.scrollHeight - paddingSize; if (minRows !== null) { var minHeight = singleRowHeight * minRows; if (boxSizing === 'border-box') { minHeight = minHeight + paddingSize + borderSize; } height = Math.max(minHeight, height); result.minHeight = minHeight + 'px'; } if (maxRows !== null) { var maxHeight = singleRowHeight * maxRows; if (boxSizing === 'border-box') { maxHeight = maxHeight + paddingSize + borderSize; } height = Math.min(maxHeight, height); } result.height = height + 'px'; hiddenTextarea.parentNode && hiddenTextarea.parentNode.removeChild(hiddenTextarea); hiddenTextarea = null; return result; }; // EXTERNAL MODULE: external "element-ui/lib/utils/merge" var merge_ = __webpack_require__(7); var merge_default = /*#__PURE__*/__webpack_require__.n(merge_); // EXTERNAL MODULE: external "element-ui/lib/utils/shared" var shared_ = __webpack_require__(19); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/input/src/input.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var inputvue_type_script_lang_js_ = ({ name: 'ElInput', componentName: 'ElInput', mixins: [emitter_default.a, migrating_default.a], inheritAttrs: false, inject: { elForm: { default: '' }, elFormItem: { default: '' } }, data: function data() { return { textareaCalcStyle: {}, hovering: false, focused: false, isComposing: false, passwordVisible: false }; }, props: { value: [String, Number], size: String, resize: String, form: String, disabled: Boolean, readonly: Boolean, type: { type: String, default: 'text' }, autosize: { type: [Boolean, Object], default: false }, autocomplete: { type: String, default: 'off' }, /** @Deprecated in next major version */ autoComplete: { type: String, validator: function validator(val) { false && false; return true; } }, validateEvent: { type: Boolean, default: true }, suffixIcon: String, prefixIcon: String, label: String, clearable: { type: Boolean, default: false }, showPassword: { type: Boolean, default: false }, showWordLimit: { type: Boolean, default: false }, tabindex: String }, computed: { _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, validateState: function validateState() { return this.elFormItem ? this.elFormItem.validateState : ''; }, needStatusIcon: function needStatusIcon() { return this.elForm ? this.elForm.statusIcon : false; }, validateIcon: function validateIcon() { return { validating: 'el-icon-loading', success: 'el-icon-circle-check', error: 'el-icon-circle-close' }[this.validateState]; }, textareaStyle: function textareaStyle() { return merge_default()({}, this.textareaCalcStyle, { resize: this.resize }); }, inputSize: function inputSize() { return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; }, inputDisabled: function inputDisabled() { return this.disabled || (this.elForm || {}).disabled; }, nativeInputValue: function nativeInputValue() { return this.value === null || this.value === undefined ? '' : String(this.value); }, showClear: function showClear() { return this.clearable && !this.inputDisabled && !this.readonly && this.nativeInputValue && (this.focused || this.hovering); }, showPwdVisible: function showPwdVisible() { return this.showPassword && !this.inputDisabled && !this.readonly && (!!this.nativeInputValue || this.focused); }, isWordLimitVisible: function isWordLimitVisible() { return this.showWordLimit && this.$attrs.maxlength && (this.type === 'text' || this.type === 'textarea') && !this.inputDisabled && !this.readonly && !this.showPassword; }, upperLimit: function upperLimit() { return this.$attrs.maxlength; }, textLength: function textLength() { if (typeof this.value === 'number') { return String(this.value).length; } return (this.value || '').length; }, inputExceed: function inputExceed() { // show exceed style if length of initial value greater then maxlength return this.isWordLimitVisible && this.textLength > this.upperLimit; } }, watch: { value: function value(val) { this.$nextTick(this.resizeTextarea); if (this.validateEvent) { this.dispatch('ElFormItem', 'el.form.change', [val]); } }, // native input value is set explicitly // do not use v-model / :value in template // see: https://github.com/ElemeFE/element/issues/14521 nativeInputValue: function nativeInputValue() { this.setNativeInputValue(); }, // when change between <input> and <textarea>, // update DOM dependent value and styles // https://github.com/ElemeFE/element/issues/14857 type: function type() { var _this = this; this.$nextTick(function () { _this.setNativeInputValue(); _this.resizeTextarea(); _this.updateIconOffset(); }); } }, methods: { focus: function focus() { this.getInput().focus(); }, blur: function blur() { this.getInput().blur(); }, getMigratingConfig: function getMigratingConfig() { return { props: { 'icon': 'icon is removed, use suffix-icon / prefix-icon instead.', 'on-icon-click': 'on-icon-click is removed.' }, events: { 'click': 'click is removed.' } }; }, handleBlur: function handleBlur(event) { this.focused = false; this.$emit('blur', event); if (this.validateEvent) { this.dispatch('ElFormItem', 'el.form.blur', [this.value]); } }, select: function select() { this.getInput().select(); }, resizeTextarea: function resizeTextarea() { if (this.$isServer) return; var autosize = this.autosize, type = this.type; if (type !== 'textarea') return; if (!autosize) { this.textareaCalcStyle = { minHeight: calcTextareaHeight(this.$refs.textarea).minHeight }; return; } var minRows = autosize.minRows; var maxRows = autosize.maxRows; this.textareaCalcStyle = calcTextareaHeight(this.$refs.textarea, minRows, maxRows); }, setNativeInputValue: function setNativeInputValue() { var input = this.getInput(); if (!input) return; if (input.value === this.nativeInputValue) return; input.value = this.nativeInputValue; }, handleFocus: function handleFocus(event) { this.focused = true; this.$emit('focus', event); }, handleCompositionStart: function handleCompositionStart() { this.isComposing = true; }, handleCompositionUpdate: function handleCompositionUpdate(event) { var text = event.target.value; var lastCharacter = text[text.length - 1] || ''; this.isComposing = !Object(shared_["isKorean"])(lastCharacter); }, handleCompositionEnd: function handleCompositionEnd(event) { if (this.isComposing) { this.isComposing = false; this.handleInput(event); } }, handleInput: function handleInput(event) { // should not emit input during composition // see: https://github.com/ElemeFE/element/issues/10516 if (this.isComposing) return; // hack for https://github.com/ElemeFE/element/issues/8548 // should remove the following line when we don't support IE if (event.target.value === this.nativeInputValue) return; this.$emit('input', event.target.value); // ensure native input value is controlled // see: https://github.com/ElemeFE/element/issues/12850 this.$nextTick(this.setNativeInputValue); }, handleChange: function handleChange(event) { this.$emit('change', event.target.value); }, calcIconOffset: function calcIconOffset(place) { var elList = [].slice.call(this.$el.querySelectorAll('.el-input__' + place) || []); if (!elList.length) return; var el = null; for (var i = 0; i < elList.length; i++) { if (elList[i].parentNode === this.$el) { el = elList[i]; break; } } if (!el) return; var pendantMap = { suffix: 'append', prefix: 'prepend' }; var pendant = pendantMap[place]; if (this.$slots[pendant]) { el.style.transform = 'translateX(' + (place === 'suffix' ? '-' : '') + this.$el.querySelector('.el-input-group__' + pendant).offsetWidth + 'px)'; } else { el.removeAttribute('style'); } }, updateIconOffset: function updateIconOffset() { this.calcIconOffset('prefix'); this.calcIconOffset('suffix'); }, clear: function clear() { this.$emit('input', ''); this.$emit('change', ''); this.$emit('clear'); }, handlePasswordVisible: function handlePasswordVisible() { this.passwordVisible = !this.passwordVisible; this.focus(); }, getInput: function getInput() { return this.$refs.input || this.$refs.textarea; }, getSuffixVisible: function getSuffixVisible() { return this.$slots.suffix || this.suffixIcon || this.showClear || this.showPassword || this.isWordLimitVisible || this.validateState && this.needStatusIcon; } }, created: function created() { this.$on('inputSelect', this.select); }, mounted: function mounted() { this.setNativeInputValue(); this.resizeTextarea(); this.updateIconOffset(); }, updated: function updated() { this.$nextTick(this.updateIconOffset); } }); // CONCATENATED MODULE: ./packages/input/src/input.vue?vue&type=script&lang=js& /* harmony default export */ var src_inputvue_type_script_lang_js_ = (inputvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/input/src/input.vue /* normalize component */ var input_component = normalizeComponent( src_inputvue_type_script_lang_js_, inputvue_type_template_id_343dd774_render, inputvue_type_template_id_343dd774_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var input_api; } input_component.options.__file = "packages/input/src/input.vue" /* harmony default export */ var src_input = (input_component.exports); // CONCATENATED MODULE: ./packages/input/index.js /* istanbul ignore next */ src_input.install = function (Vue) { Vue.component(src_input.name, src_input); }; /* harmony default export */ var packages_input = (src_input); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/input-number/src/input-number.vue?vue&type=template&id=42f8cf66& var input_numbervue_type_template_id_42f8cf66_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { class: [ "el-input-number", _vm.inputNumberSize ? "el-input-number--" + _vm.inputNumberSize : "", { "is-disabled": _vm.inputNumberDisabled }, { "is-without-controls": !_vm.controls }, { "is-controls-right": _vm.controlsAtRight } ], on: { dragstart: function($event) { $event.preventDefault() } } }, [ _vm.controls ? _c( "span", { directives: [ { name: "repeat-click", rawName: "v-repeat-click", value: _vm.decrease, expression: "decrease" } ], staticClass: "el-input-number__decrease", class: { "is-disabled": _vm.minDisabled }, attrs: { role: "button" }, on: { keydown: function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter") ) { return null } return _vm.decrease($event) } } }, [ _c("i", { class: "el-icon-" + (_vm.controlsAtRight ? "arrow-down" : "minus") }) ] ) : _vm._e(), _vm.controls ? _c( "span", { directives: [ { name: "repeat-click", rawName: "v-repeat-click", value: _vm.increase, expression: "increase" } ], staticClass: "el-input-number__increase", class: { "is-disabled": _vm.maxDisabled }, attrs: { role: "button" }, on: { keydown: function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter") ) { return null } return _vm.increase($event) } } }, [ _c("i", { class: "el-icon-" + (_vm.controlsAtRight ? "arrow-up" : "plus") }) ] ) : _vm._e(), _c("el-input", { ref: "input", attrs: { value: _vm.displayValue, placeholder: _vm.placeholder, disabled: _vm.inputNumberDisabled, size: _vm.inputNumberSize, max: _vm.max, min: _vm.min, name: _vm.name, label: _vm.label }, on: { blur: _vm.handleBlur, focus: _vm.handleFocus, input: _vm.handleInput, change: _vm.handleInputChange }, nativeOn: { keydown: [ function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "up", 38, $event.key, ["Up", "ArrowUp"]) ) { return null } $event.preventDefault() return _vm.increase($event) }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "down", 40, $event.key, [ "Down", "ArrowDown" ]) ) { return null } $event.preventDefault() return _vm.decrease($event) } ] } }) ], 1 ) } var input_numbervue_type_template_id_42f8cf66_staticRenderFns = [] input_numbervue_type_template_id_42f8cf66_render._withStripped = true // CONCATENATED MODULE: ./packages/input-number/src/input-number.vue?vue&type=template&id=42f8cf66& // CONCATENATED MODULE: ./src/directives/repeat-click.js /* harmony default export */ var repeat_click = ({ bind: function bind(el, binding, vnode) { var interval = null; var startTime = void 0; var handler = function handler() { return vnode.context[binding.expression].apply(); }; var clear = function clear() { if (Date.now() - startTime < 100) { handler(); } clearInterval(interval); interval = null; }; Object(dom_["on"])(el, 'mousedown', function (e) { if (e.button !== 0) return; startTime = Date.now(); Object(dom_["once"])(document, 'mouseup', clear); clearInterval(interval); interval = setInterval(handler, 100); }); } }); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/input-number/src/input-number.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var input_numbervue_type_script_lang_js_ = ({ name: 'ElInputNumber', mixins: [focus_default()('input')], inject: { elForm: { default: '' }, elFormItem: { default: '' } }, directives: { repeatClick: repeat_click }, components: { ElInput: input_default.a }, props: { step: { type: Number, default: 1 }, stepStrictly: { type: Boolean, default: false }, max: { type: Number, default: Infinity }, min: { type: Number, default: -Infinity }, value: {}, disabled: Boolean, size: String, controls: { type: Boolean, default: true }, controlsPosition: { type: String, default: '' }, name: String, label: String, placeholder: String, precision: { type: Number, validator: function validator(val) { return val >= 0 && val === parseInt(val, 10); } } }, data: function data() { return { currentValue: 0, userInput: null }; }, watch: { value: { immediate: true, handler: function handler(value) { var newVal = value === undefined ? value : Number(value); if (newVal !== undefined) { if (isNaN(newVal)) { return; } if (this.stepStrictly) { var stepPrecision = this.getPrecision(this.step); var precisionFactor = Math.pow(10, stepPrecision); newVal = Math.round(newVal / this.step) * precisionFactor * this.step / precisionFactor; } if (this.precision !== undefined) { newVal = this.toPrecision(newVal, this.precision); } } if (newVal >= this.max) newVal = this.max; if (newVal <= this.min) newVal = this.min; this.currentValue = newVal; this.userInput = null; this.$emit('input', newVal); } } }, computed: { minDisabled: function minDisabled() { return this._decrease(this.value, this.step) < this.min; }, maxDisabled: function maxDisabled() { return this._increase(this.value, this.step) > this.max; }, numPrecision: function numPrecision() { var value = this.value, step = this.step, getPrecision = this.getPrecision, precision = this.precision; var stepPrecision = getPrecision(step); if (precision !== undefined) { if (stepPrecision > precision) { console.warn('[Element Warn][InputNumber]precision should not be less than the decimal places of step'); } return precision; } else { return Math.max(getPrecision(value), stepPrecision); } }, controlsAtRight: function controlsAtRight() { return this.controls && this.controlsPosition === 'right'; }, _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, inputNumberSize: function inputNumberSize() { return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; }, inputNumberDisabled: function inputNumberDisabled() { return this.disabled || !!(this.elForm || {}).disabled; }, displayValue: function displayValue() { if (this.userInput !== null) { return this.userInput; } var currentValue = this.currentValue; if (typeof currentValue === 'number') { if (this.stepStrictly) { var stepPrecision = this.getPrecision(this.step); var precisionFactor = Math.pow(10, stepPrecision); currentValue = Math.round(currentValue / this.step) * precisionFactor * this.step / precisionFactor; } if (this.precision !== undefined) { currentValue = currentValue.toFixed(this.precision); } } return currentValue; } }, methods: { toPrecision: function toPrecision(num, precision) { if (precision === undefined) precision = this.numPrecision; return parseFloat(Math.round(num * Math.pow(10, precision)) / Math.pow(10, precision)); }, getPrecision: function getPrecision(value) { if (value === undefined) return 0; var valueString = value.toString(); var dotPosition = valueString.indexOf('.'); var precision = 0; if (dotPosition !== -1) { precision = valueString.length - dotPosition - 1; } return precision; }, _increase: function _increase(val, step) { if (typeof val !== 'number' && val !== undefined) return this.currentValue; var precisionFactor = Math.pow(10, this.numPrecision); // Solve the accuracy problem of JS decimal calculation by converting the value to integer. return this.toPrecision((precisionFactor * val + precisionFactor * step) / precisionFactor); }, _decrease: function _decrease(val, step) { if (typeof val !== 'number' && val !== undefined) return this.currentValue; var precisionFactor = Math.pow(10, this.numPrecision); return this.toPrecision((precisionFactor * val - precisionFactor * step) / precisionFactor); }, increase: function increase() { if (this.inputNumberDisabled || this.maxDisabled) return; var value = this.value || 0; var newVal = this._increase(value, this.step); this.setCurrentValue(newVal); }, decrease: function decrease() { if (this.inputNumberDisabled || this.minDisabled) return; var value = this.value || 0; var newVal = this._decrease(value, this.step); this.setCurrentValue(newVal); }, handleBlur: function handleBlur(event) { this.$emit('blur', event); }, handleFocus: function handleFocus(event) { this.$emit('focus', event); }, setCurrentValue: function setCurrentValue(newVal) { var oldVal = this.currentValue; if (typeof newVal === 'number' && this.precision !== undefined) { newVal = this.toPrecision(newVal, this.precision); } if (newVal >= this.max) newVal = this.max; if (newVal <= this.min) newVal = this.min; if (oldVal === newVal) return; this.userInput = null; this.$emit('input', newVal); this.$emit('change', newVal, oldVal); this.currentValue = newVal; }, handleInput: function handleInput(value) { this.userInput = value; }, handleInputChange: function handleInputChange(value) { var newVal = value === '' ? undefined : Number(value); if (!isNaN(newVal) || value === '') { this.setCurrentValue(newVal); } this.userInput = null; }, select: function select() { this.$refs.input.select(); } }, mounted: function mounted() { var innerInput = this.$refs.input.$refs.input; innerInput.setAttribute('role', 'spinbutton'); innerInput.setAttribute('aria-valuemax', this.max); innerInput.setAttribute('aria-valuemin', this.min); innerInput.setAttribute('aria-valuenow', this.currentValue); innerInput.setAttribute('aria-disabled', this.inputNumberDisabled); }, updated: function updated() { if (!this.$refs || !this.$refs.input) return; var innerInput = this.$refs.input.$refs.input; innerInput.setAttribute('aria-valuenow', this.currentValue); } }); // CONCATENATED MODULE: ./packages/input-number/src/input-number.vue?vue&type=script&lang=js& /* harmony default export */ var src_input_numbervue_type_script_lang_js_ = (input_numbervue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/input-number/src/input-number.vue /* normalize component */ var input_number_component = normalizeComponent( src_input_numbervue_type_script_lang_js_, input_numbervue_type_template_id_42f8cf66_render, input_numbervue_type_template_id_42f8cf66_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var input_number_api; } input_number_component.options.__file = "packages/input-number/src/input-number.vue" /* harmony default export */ var input_number = (input_number_component.exports); // CONCATENATED MODULE: ./packages/input-number/index.js /* istanbul ignore next */ input_number.install = function (Vue) { Vue.component(input_number.name, input_number); }; /* harmony default export */ var packages_input_number = (input_number); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio.vue?vue&type=template&id=69cd6268& var radiovue_type_template_id_69cd6268_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "label", { staticClass: "el-radio", class: [ _vm.border && _vm.radioSize ? "el-radio--" + _vm.radioSize : "", { "is-disabled": _vm.isDisabled }, { "is-focus": _vm.focus }, { "is-bordered": _vm.border }, { "is-checked": _vm.model === _vm.label } ], attrs: { role: "radio", "aria-checked": _vm.model === _vm.label, "aria-disabled": _vm.isDisabled, tabindex: _vm.tabIndex }, on: { keydown: function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "space", 32, $event.key, [" ", "Spacebar"]) ) { return null } $event.stopPropagation() $event.preventDefault() _vm.model = _vm.isDisabled ? _vm.model : _vm.label } } }, [ _c( "span", { staticClass: "el-radio__input", class: { "is-disabled": _vm.isDisabled, "is-checked": _vm.model === _vm.label } }, [ _c("span", { staticClass: "el-radio__inner" }), _c("input", { directives: [ { name: "model", rawName: "v-model", value: _vm.model, expression: "model" } ], ref: "radio", staticClass: "el-radio__original", attrs: { type: "radio", "aria-hidden": "true", name: _vm.name, disabled: _vm.isDisabled, tabindex: "-1" }, domProps: { value: _vm.label, checked: _vm._q(_vm.model, _vm.label) }, on: { focus: function($event) { _vm.focus = true }, blur: function($event) { _vm.focus = false }, change: [ function($event) { _vm.model = _vm.label }, _vm.handleChange ] } }) ] ), _c( "span", { staticClass: "el-radio__label", on: { keydown: function($event) { $event.stopPropagation() } } }, [ _vm._t("default"), !_vm.$slots.default ? [_vm._v(_vm._s(_vm.label))] : _vm._e() ], 2 ) ] ) } var radiovue_type_template_id_69cd6268_staticRenderFns = [] radiovue_type_template_id_69cd6268_render._withStripped = true // CONCATENATED MODULE: ./packages/radio/src/radio.vue?vue&type=template&id=69cd6268& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var radiovue_type_script_lang_js_ = ({ name: 'ElRadio', mixins: [emitter_default.a], inject: { elForm: { default: '' }, elFormItem: { default: '' } }, componentName: 'ElRadio', props: { value: {}, label: {}, disabled: Boolean, name: String, border: Boolean, size: String }, data: function data() { return { focus: false }; }, computed: { isGroup: function isGroup() { var parent = this.$parent; while (parent) { if (parent.$options.componentName !== 'ElRadioGroup') { parent = parent.$parent; } else { this._radioGroup = parent; return true; } } return false; }, model: { get: function get() { return this.isGroup ? this._radioGroup.value : this.value; }, set: function set(val) { if (this.isGroup) { this.dispatch('ElRadioGroup', 'input', [val]); } else { this.$emit('input', val); } this.$refs.radio && (this.$refs.radio.checked = this.model === this.label); } }, _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, radioSize: function radioSize() { var temRadioSize = this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; return this.isGroup ? this._radioGroup.radioGroupSize || temRadioSize : temRadioSize; }, isDisabled: function isDisabled() { return this.isGroup ? this._radioGroup.disabled || this.disabled || (this.elForm || {}).disabled : this.disabled || (this.elForm || {}).disabled; }, tabIndex: function tabIndex() { return this.isDisabled || this.isGroup && this.model !== this.label ? -1 : 0; } }, methods: { handleChange: function handleChange() { var _this = this; this.$nextTick(function () { _this.$emit('change', _this.model); _this.isGroup && _this.dispatch('ElRadioGroup', 'handleChange', _this.model); }); } } }); // CONCATENATED MODULE: ./packages/radio/src/radio.vue?vue&type=script&lang=js& /* harmony default export */ var src_radiovue_type_script_lang_js_ = (radiovue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/radio/src/radio.vue /* normalize component */ var radio_component = normalizeComponent( src_radiovue_type_script_lang_js_, radiovue_type_template_id_69cd6268_render, radiovue_type_template_id_69cd6268_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var radio_api; } radio_component.options.__file = "packages/radio/src/radio.vue" /* harmony default export */ var src_radio = (radio_component.exports); // CONCATENATED MODULE: ./packages/radio/index.js /* istanbul ignore next */ src_radio.install = function (Vue) { Vue.component(src_radio.name, src_radio); }; /* harmony default export */ var packages_radio = (src_radio); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio-group.vue?vue&type=template&id=818a704c& var radio_groupvue_type_template_id_818a704c_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( _vm._elTag, { tag: "component", staticClass: "el-radio-group", attrs: { role: "radiogroup" }, on: { keydown: _vm.handleKeydown } }, [_vm._t("default")], 2 ) } var radio_groupvue_type_template_id_818a704c_staticRenderFns = [] radio_groupvue_type_template_id_818a704c_render._withStripped = true // CONCATENATED MODULE: ./packages/radio/src/radio-group.vue?vue&type=template&id=818a704c& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio-group.vue?vue&type=script&lang=js& // // // // // // // // // // var keyCode = Object.freeze({ LEFT: 37, UP: 38, RIGHT: 39, DOWN: 40 }); /* harmony default export */ var radio_groupvue_type_script_lang_js_ = ({ name: 'ElRadioGroup', componentName: 'ElRadioGroup', inject: { elFormItem: { default: '' } }, mixins: [emitter_default.a], props: { value: {}, size: String, fill: String, textColor: String, disabled: Boolean }, computed: { _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, _elTag: function _elTag() { return (this.$vnode.data || {}).tag || 'div'; }, radioGroupSize: function radioGroupSize() { return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; } }, created: function created() { var _this = this; this.$on('handleChange', function (value) { _this.$emit('change', value); }); }, mounted: function mounted() { // 当radioGroup没有默认选项时,第一个可以选中Tab导航 var radios = this.$el.querySelectorAll('[type=radio]'); var firstLabel = this.$el.querySelectorAll('[role=radio]')[0]; if (![].some.call(radios, function (radio) { return radio.checked; }) && firstLabel) { firstLabel.tabIndex = 0; } }, methods: { handleKeydown: function handleKeydown(e) { // 左右上下按键 可以在radio组内切换不同选项 var target = e.target; var className = target.nodeName === 'INPUT' ? '[type=radio]' : '[role=radio]'; var radios = this.$el.querySelectorAll(className); var length = radios.length; var index = [].indexOf.call(radios, target); var roleRadios = this.$el.querySelectorAll('[role=radio]'); switch (e.keyCode) { case keyCode.LEFT: case keyCode.UP: e.stopPropagation(); e.preventDefault(); if (index === 0) { roleRadios[length - 1].click(); roleRadios[length - 1].focus(); } else { roleRadios[index - 1].click(); roleRadios[index - 1].focus(); } break; case keyCode.RIGHT: case keyCode.DOWN: if (index === length - 1) { e.stopPropagation(); e.preventDefault(); roleRadios[0].click(); roleRadios[0].focus(); } else { roleRadios[index + 1].click(); roleRadios[index + 1].focus(); } break; default: break; } } }, watch: { value: function value(_value) { this.dispatch('ElFormItem', 'el.form.change', [this.value]); } } }); // CONCATENATED MODULE: ./packages/radio/src/radio-group.vue?vue&type=script&lang=js& /* harmony default export */ var src_radio_groupvue_type_script_lang_js_ = (radio_groupvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/radio/src/radio-group.vue /* normalize component */ var radio_group_component = normalizeComponent( src_radio_groupvue_type_script_lang_js_, radio_groupvue_type_template_id_818a704c_render, radio_groupvue_type_template_id_818a704c_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var radio_group_api; } radio_group_component.options.__file = "packages/radio/src/radio-group.vue" /* harmony default export */ var radio_group = (radio_group_component.exports); // CONCATENATED MODULE: ./packages/radio-group/index.js /* istanbul ignore next */ radio_group.install = function (Vue) { Vue.component(radio_group.name, radio_group); }; /* harmony default export */ var packages_radio_group = (radio_group); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio-button.vue?vue&type=template&id=18a77a32& var radio_buttonvue_type_template_id_18a77a32_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "label", { staticClass: "el-radio-button", class: [ _vm.size ? "el-radio-button--" + _vm.size : "", { "is-active": _vm.value === _vm.label }, { "is-disabled": _vm.isDisabled }, { "is-focus": _vm.focus } ], attrs: { role: "radio", "aria-checked": _vm.value === _vm.label, "aria-disabled": _vm.isDisabled, tabindex: _vm.tabIndex }, on: { keydown: function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "space", 32, $event.key, [" ", "Spacebar"]) ) { return null } $event.stopPropagation() $event.preventDefault() _vm.value = _vm.isDisabled ? _vm.value : _vm.label } } }, [ _c("input", { directives: [ { name: "model", rawName: "v-model", value: _vm.value, expression: "value" } ], staticClass: "el-radio-button__orig-radio", attrs: { type: "radio", name: _vm.name, disabled: _vm.isDisabled, tabindex: "-1" }, domProps: { value: _vm.label, checked: _vm._q(_vm.value, _vm.label) }, on: { change: [ function($event) { _vm.value = _vm.label }, _vm.handleChange ], focus: function($event) { _vm.focus = true }, blur: function($event) { _vm.focus = false } } }), _c( "span", { staticClass: "el-radio-button__inner", style: _vm.value === _vm.label ? _vm.activeStyle : null, on: { keydown: function($event) { $event.stopPropagation() } } }, [ _vm._t("default"), !_vm.$slots.default ? [_vm._v(_vm._s(_vm.label))] : _vm._e() ], 2 ) ] ) } var radio_buttonvue_type_template_id_18a77a32_staticRenderFns = [] radio_buttonvue_type_template_id_18a77a32_render._withStripped = true // CONCATENATED MODULE: ./packages/radio/src/radio-button.vue?vue&type=template&id=18a77a32& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/radio/src/radio-button.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var radio_buttonvue_type_script_lang_js_ = ({ name: 'ElRadioButton', mixins: [emitter_default.a], inject: { elForm: { default: '' }, elFormItem: { default: '' } }, props: { label: {}, disabled: Boolean, name: String }, data: function data() { return { focus: false }; }, computed: { value: { get: function get() { return this._radioGroup.value; }, set: function set(value) { this._radioGroup.$emit('input', value); } }, _radioGroup: function _radioGroup() { var parent = this.$parent; while (parent) { if (parent.$options.componentName !== 'ElRadioGroup') { parent = parent.$parent; } else { return parent; } } return false; }, activeStyle: function activeStyle() { return { backgroundColor: this._radioGroup.fill || '', borderColor: this._radioGroup.fill || '', boxShadow: this._radioGroup.fill ? '-1px 0 0 0 ' + this._radioGroup.fill : '', color: this._radioGroup.textColor || '' }; }, _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, size: function size() { return this._radioGroup.radioGroupSize || this._elFormItemSize || (this.$ELEMENT || {}).size; }, isDisabled: function isDisabled() { return this.disabled || this._radioGroup.disabled || (this.elForm || {}).disabled; }, tabIndex: function tabIndex() { return this.isDisabled || this._radioGroup && this.value !== this.label ? -1 : 0; } }, methods: { handleChange: function handleChange() { var _this = this; this.$nextTick(function () { _this.dispatch('ElRadioGroup', 'handleChange', _this.value); }); } } }); // CONCATENATED MODULE: ./packages/radio/src/radio-button.vue?vue&type=script&lang=js& /* harmony default export */ var src_radio_buttonvue_type_script_lang_js_ = (radio_buttonvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/radio/src/radio-button.vue /* normalize component */ var radio_button_component = normalizeComponent( src_radio_buttonvue_type_script_lang_js_, radio_buttonvue_type_template_id_18a77a32_render, radio_buttonvue_type_template_id_18a77a32_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var radio_button_api; } radio_button_component.options.__file = "packages/radio/src/radio-button.vue" /* harmony default export */ var radio_button = (radio_button_component.exports); // CONCATENATED MODULE: ./packages/radio-button/index.js /* istanbul ignore next */ radio_button.install = function (Vue) { Vue.component(radio_button.name, radio_button); }; /* harmony default export */ var packages_radio_button = (radio_button); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox.vue?vue&type=template&id=d0387074& var checkboxvue_type_template_id_d0387074_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "label", { staticClass: "el-checkbox", class: [ _vm.border && _vm.checkboxSize ? "el-checkbox--" + _vm.checkboxSize : "", { "is-disabled": _vm.isDisabled }, { "is-bordered": _vm.border }, { "is-checked": _vm.isChecked } ], attrs: { id: _vm.id } }, [ _c( "span", { staticClass: "el-checkbox__input", class: { "is-disabled": _vm.isDisabled, "is-checked": _vm.isChecked, "is-indeterminate": _vm.indeterminate, "is-focus": _vm.focus }, attrs: { tabindex: _vm.indeterminate ? 0 : false, role: _vm.indeterminate ? "checkbox" : false, "aria-checked": _vm.indeterminate ? "mixed" : false } }, [ _c("span", { staticClass: "el-checkbox__inner" }), _vm.trueLabel || _vm.falseLabel ? _c("input", { directives: [ { name: "model", rawName: "v-model", value: _vm.model, expression: "model" } ], staticClass: "el-checkbox__original", attrs: { type: "checkbox", "aria-hidden": _vm.indeterminate ? "true" : "false", name: _vm.name, disabled: _vm.isDisabled, "true-value": _vm.trueLabel, "false-value": _vm.falseLabel }, domProps: { checked: Array.isArray(_vm.model) ? _vm._i(_vm.model, null) > -1 : _vm._q(_vm.model, _vm.trueLabel) }, on: { change: [ function($event) { var $$a = _vm.model, $$el = $event.target, $$c = $$el.checked ? _vm.trueLabel : _vm.falseLabel if (Array.isArray($$a)) { var $$v = null, $$i = _vm._i($$a, $$v) if ($$el.checked) { $$i < 0 && (_vm.model = $$a.concat([$$v])) } else { $$i > -1 && (_vm.model = $$a .slice(0, $$i) .concat($$a.slice($$i + 1))) } } else { _vm.model = $$c } }, _vm.handleChange ], focus: function($event) { _vm.focus = true }, blur: function($event) { _vm.focus = false } } }) : _c("input", { directives: [ { name: "model", rawName: "v-model", value: _vm.model, expression: "model" } ], staticClass: "el-checkbox__original", attrs: { type: "checkbox", "aria-hidden": _vm.indeterminate ? "true" : "false", disabled: _vm.isDisabled, name: _vm.name }, domProps: { value: _vm.label, checked: Array.isArray(_vm.model) ? _vm._i(_vm.model, _vm.label) > -1 : _vm.model }, on: { change: [ function($event) { var $$a = _vm.model, $$el = $event.target, $$c = $$el.checked ? true : false if (Array.isArray($$a)) { var $$v = _vm.label, $$i = _vm._i($$a, $$v) if ($$el.checked) { $$i < 0 && (_vm.model = $$a.concat([$$v])) } else { $$i > -1 && (_vm.model = $$a .slice(0, $$i) .concat($$a.slice($$i + 1))) } } else { _vm.model = $$c } }, _vm.handleChange ], focus: function($event) { _vm.focus = true }, blur: function($event) { _vm.focus = false } } }) ] ), _vm.$slots.default || _vm.label ? _c( "span", { staticClass: "el-checkbox__label" }, [ _vm._t("default"), !_vm.$slots.default ? [_vm._v(_vm._s(_vm.label))] : _vm._e() ], 2 ) : _vm._e() ] ) } var checkboxvue_type_template_id_d0387074_staticRenderFns = [] checkboxvue_type_template_id_d0387074_render._withStripped = true // CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue?vue&type=template&id=d0387074& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var checkboxvue_type_script_lang_js_ = ({ name: 'ElCheckbox', mixins: [emitter_default.a], inject: { elForm: { default: '' }, elFormItem: { default: '' } }, componentName: 'ElCheckbox', data: function data() { return { selfModel: false, focus: false, isLimitExceeded: false }; }, computed: { model: { get: function get() { return this.isGroup ? this.store : this.value !== undefined ? this.value : this.selfModel; }, set: function set(val) { if (this.isGroup) { this.isLimitExceeded = false; this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (this.isLimitExceeded = true); this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (this.isLimitExceeded = true); this.isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]); } else { this.$emit('input', val); this.selfModel = val; } } }, isChecked: function isChecked() { if ({}.toString.call(this.model) === '[object Boolean]') { return this.model; } else if (Array.isArray(this.model)) { return this.model.indexOf(this.label) > -1; } else if (this.model !== null && this.model !== undefined) { return this.model === this.trueLabel; } }, isGroup: function isGroup() { var parent = this.$parent; while (parent) { if (parent.$options.componentName !== 'ElCheckboxGroup') { parent = parent.$parent; } else { this._checkboxGroup = parent; return true; } } return false; }, store: function store() { return this._checkboxGroup ? this._checkboxGroup.value : this.value; }, /* used to make the isDisabled judgment under max/min props */ isLimitDisabled: function isLimitDisabled() { var _checkboxGroup = this._checkboxGroup, max = _checkboxGroup.max, min = _checkboxGroup.min; return !!(max || min) && this.model.length >= max && !this.isChecked || this.model.length <= min && this.isChecked; }, isDisabled: function isDisabled() { return this.isGroup ? this._checkboxGroup.disabled || this.disabled || (this.elForm || {}).disabled || this.isLimitDisabled : this.disabled || (this.elForm || {}).disabled; }, _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, checkboxSize: function checkboxSize() { var temCheckboxSize = this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; return this.isGroup ? this._checkboxGroup.checkboxGroupSize || temCheckboxSize : temCheckboxSize; } }, props: { value: {}, label: {}, indeterminate: Boolean, disabled: Boolean, checked: Boolean, name: String, trueLabel: [String, Number], falseLabel: [String, Number], id: String, /* 当indeterminate为真时,为controls提供相关连的checkbox的id,表明元素间的控制关系*/ controls: String, /* 当indeterminate为真时,为controls提供相关连的checkbox的id,表明元素间的控制关系*/ border: Boolean, size: String }, methods: { addToStore: function addToStore() { if (Array.isArray(this.model) && this.model.indexOf(this.label) === -1) { this.model.push(this.label); } else { this.model = this.trueLabel || true; } }, handleChange: function handleChange(ev) { var _this = this; if (this.isLimitExceeded) return; var value = void 0; if (ev.target.checked) { value = this.trueLabel === undefined ? true : this.trueLabel; } else { value = this.falseLabel === undefined ? false : this.falseLabel; } this.$emit('change', value, ev); this.$nextTick(function () { if (_this.isGroup) { _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]); } }); } }, created: function created() { this.checked && this.addToStore(); }, mounted: function mounted() { // 为indeterminate元素 添加aria-controls 属性 if (this.indeterminate) { this.$el.setAttribute('aria-controls', this.controls); } }, watch: { value: function value(_value) { this.dispatch('ElFormItem', 'el.form.change', _value); } } }); // CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue?vue&type=script&lang=js& /* harmony default export */ var src_checkboxvue_type_script_lang_js_ = (checkboxvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/checkbox/src/checkbox.vue /* normalize component */ var checkbox_component = normalizeComponent( src_checkboxvue_type_script_lang_js_, checkboxvue_type_template_id_d0387074_render, checkboxvue_type_template_id_d0387074_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var checkbox_api; } checkbox_component.options.__file = "packages/checkbox/src/checkbox.vue" /* harmony default export */ var src_checkbox = (checkbox_component.exports); // CONCATENATED MODULE: ./packages/checkbox/index.js /* istanbul ignore next */ src_checkbox.install = function (Vue) { Vue.component(src_checkbox.name, src_checkbox); }; /* harmony default export */ var packages_checkbox = (src_checkbox); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-button.vue?vue&type=template&id=478e906e& var checkbox_buttonvue_type_template_id_478e906e_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "label", { staticClass: "el-checkbox-button", class: [ _vm.size ? "el-checkbox-button--" + _vm.size : "", { "is-disabled": _vm.isDisabled }, { "is-checked": _vm.isChecked }, { "is-focus": _vm.focus } ], attrs: { role: "checkbox", "aria-checked": _vm.isChecked, "aria-disabled": _vm.isDisabled } }, [ _vm.trueLabel || _vm.falseLabel ? _c("input", { directives: [ { name: "model", rawName: "v-model", value: _vm.model, expression: "model" } ], staticClass: "el-checkbox-button__original", attrs: { type: "checkbox", name: _vm.name, disabled: _vm.isDisabled, "true-value": _vm.trueLabel, "false-value": _vm.falseLabel }, domProps: { checked: Array.isArray(_vm.model) ? _vm._i(_vm.model, null) > -1 : _vm._q(_vm.model, _vm.trueLabel) }, on: { change: [ function($event) { var $$a = _vm.model, $$el = $event.target, $$c = $$el.checked ? _vm.trueLabel : _vm.falseLabel if (Array.isArray($$a)) { var $$v = null, $$i = _vm._i($$a, $$v) if ($$el.checked) { $$i < 0 && (_vm.model = $$a.concat([$$v])) } else { $$i > -1 && (_vm.model = $$a .slice(0, $$i) .concat($$a.slice($$i + 1))) } } else { _vm.model = $$c } }, _vm.handleChange ], focus: function($event) { _vm.focus = true }, blur: function($event) { _vm.focus = false } } }) : _c("input", { directives: [ { name: "model", rawName: "v-model", value: _vm.model, expression: "model" } ], staticClass: "el-checkbox-button__original", attrs: { type: "checkbox", name: _vm.name, disabled: _vm.isDisabled }, domProps: { value: _vm.label, checked: Array.isArray(_vm.model) ? _vm._i(_vm.model, _vm.label) > -1 : _vm.model }, on: { change: [ function($event) { var $$a = _vm.model, $$el = $event.target, $$c = $$el.checked ? true : false if (Array.isArray($$a)) { var $$v = _vm.label, $$i = _vm._i($$a, $$v) if ($$el.checked) { $$i < 0 && (_vm.model = $$a.concat([$$v])) } else { $$i > -1 && (_vm.model = $$a .slice(0, $$i) .concat($$a.slice($$i + 1))) } } else { _vm.model = $$c } }, _vm.handleChange ], focus: function($event) { _vm.focus = true }, blur: function($event) { _vm.focus = false } } }), _vm.$slots.default || _vm.label ? _c( "span", { staticClass: "el-checkbox-button__inner", style: _vm.isChecked ? _vm.activeStyle : null }, [_vm._t("default", [_vm._v(_vm._s(_vm.label))])], 2 ) : _vm._e() ] ) } var checkbox_buttonvue_type_template_id_478e906e_staticRenderFns = [] checkbox_buttonvue_type_template_id_478e906e_render._withStripped = true // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-button.vue?vue&type=template&id=478e906e& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-button.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var checkbox_buttonvue_type_script_lang_js_ = ({ name: 'ElCheckboxButton', mixins: [emitter_default.a], inject: { elForm: { default: '' }, elFormItem: { default: '' } }, data: function data() { return { selfModel: false, focus: false, isLimitExceeded: false }; }, props: { value: {}, label: {}, disabled: Boolean, checked: Boolean, name: String, trueLabel: [String, Number], falseLabel: [String, Number] }, computed: { model: { get: function get() { return this._checkboxGroup ? this.store : this.value !== undefined ? this.value : this.selfModel; }, set: function set(val) { if (this._checkboxGroup) { this.isLimitExceeded = false; this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (this.isLimitExceeded = true); this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (this.isLimitExceeded = true); this.isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]); } else if (this.value !== undefined) { this.$emit('input', val); } else { this.selfModel = val; } } }, isChecked: function isChecked() { if ({}.toString.call(this.model) === '[object Boolean]') { return this.model; } else if (Array.isArray(this.model)) { return this.model.indexOf(this.label) > -1; } else if (this.model !== null && this.model !== undefined) { return this.model === this.trueLabel; } }, _checkboxGroup: function _checkboxGroup() { var parent = this.$parent; while (parent) { if (parent.$options.componentName !== 'ElCheckboxGroup') { parent = parent.$parent; } else { return parent; } } return false; }, store: function store() { return this._checkboxGroup ? this._checkboxGroup.value : this.value; }, activeStyle: function activeStyle() { return { backgroundColor: this._checkboxGroup.fill || '', borderColor: this._checkboxGroup.fill || '', color: this._checkboxGroup.textColor || '', 'box-shadow': '-1px 0 0 0 ' + this._checkboxGroup.fill }; }, _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, size: function size() { return this._checkboxGroup.checkboxGroupSize || this._elFormItemSize || (this.$ELEMENT || {}).size; }, /* used to make the isDisabled judgment under max/min props */ isLimitDisabled: function isLimitDisabled() { var _checkboxGroup2 = this._checkboxGroup, max = _checkboxGroup2.max, min = _checkboxGroup2.min; return !!(max || min) && this.model.length >= max && !this.isChecked || this.model.length <= min && this.isChecked; }, isDisabled: function isDisabled() { return this._checkboxGroup ? this._checkboxGroup.disabled || this.disabled || (this.elForm || {}).disabled || this.isLimitDisabled : this.disabled || (this.elForm || {}).disabled; } }, methods: { addToStore: function addToStore() { if (Array.isArray(this.model) && this.model.indexOf(this.label) === -1) { this.model.push(this.label); } else { this.model = this.trueLabel || true; } }, handleChange: function handleChange(ev) { var _this = this; if (this.isLimitExceeded) return; var value = void 0; if (ev.target.checked) { value = this.trueLabel === undefined ? true : this.trueLabel; } else { value = this.falseLabel === undefined ? false : this.falseLabel; } this.$emit('change', value, ev); this.$nextTick(function () { if (_this._checkboxGroup) { _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]); } }); } }, created: function created() { this.checked && this.addToStore(); } }); // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-button.vue?vue&type=script&lang=js& /* harmony default export */ var src_checkbox_buttonvue_type_script_lang_js_ = (checkbox_buttonvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-button.vue /* normalize component */ var checkbox_button_component = normalizeComponent( src_checkbox_buttonvue_type_script_lang_js_, checkbox_buttonvue_type_template_id_478e906e_render, checkbox_buttonvue_type_template_id_478e906e_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var checkbox_button_api; } checkbox_button_component.options.__file = "packages/checkbox/src/checkbox-button.vue" /* harmony default export */ var checkbox_button = (checkbox_button_component.exports); // CONCATENATED MODULE: ./packages/checkbox-button/index.js /* istanbul ignore next */ checkbox_button.install = function (Vue) { Vue.component(checkbox_button.name, checkbox_button); }; /* harmony default export */ var packages_checkbox_button = (checkbox_button); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-group.vue?vue&type=template&id=7289a290& var checkbox_groupvue_type_template_id_7289a290_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-checkbox-group", attrs: { role: "group", "aria-label": "checkbox-group" } }, [_vm._t("default")], 2 ) } var checkbox_groupvue_type_template_id_7289a290_staticRenderFns = [] checkbox_groupvue_type_template_id_7289a290_render._withStripped = true // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue?vue&type=template&id=7289a290& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/checkbox/src/checkbox-group.vue?vue&type=script&lang=js& /* harmony default export */ var checkbox_groupvue_type_script_lang_js_ = ({ name: 'ElCheckboxGroup', componentName: 'ElCheckboxGroup', mixins: [emitter_default.a], inject: { elFormItem: { default: '' } }, props: { value: {}, disabled: Boolean, min: Number, max: Number, size: String, fill: String, textColor: String }, computed: { _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, checkboxGroupSize: function checkboxGroupSize() { return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; } }, watch: { value: function value(_value) { this.dispatch('ElFormItem', 'el.form.change', [_value]); } } }); // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue?vue&type=script&lang=js& /* harmony default export */ var src_checkbox_groupvue_type_script_lang_js_ = (checkbox_groupvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/checkbox/src/checkbox-group.vue /* normalize component */ var checkbox_group_component = normalizeComponent( src_checkbox_groupvue_type_script_lang_js_, checkbox_groupvue_type_template_id_7289a290_render, checkbox_groupvue_type_template_id_7289a290_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var checkbox_group_api; } checkbox_group_component.options.__file = "packages/checkbox/src/checkbox-group.vue" /* harmony default export */ var checkbox_group = (checkbox_group_component.exports); // CONCATENATED MODULE: ./packages/checkbox-group/index.js /* istanbul ignore next */ checkbox_group.install = function (Vue) { Vue.component(checkbox_group.name, checkbox_group); }; /* harmony default export */ var packages_checkbox_group = (checkbox_group); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/switch/src/component.vue?vue&type=template&id=2dcd8fbb& var componentvue_type_template_id_2dcd8fbb_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-switch", class: { "is-disabled": _vm.switchDisabled, "is-checked": _vm.checked }, attrs: { role: "switch", "aria-checked": _vm.checked, "aria-disabled": _vm.switchDisabled }, on: { click: function($event) { $event.preventDefault() return _vm.switchValue($event) } } }, [ _c("input", { ref: "input", staticClass: "el-switch__input", attrs: { type: "checkbox", id: _vm.id, name: _vm.name, "true-value": _vm.activeValue, "false-value": _vm.inactiveValue, disabled: _vm.switchDisabled }, on: { change: _vm.handleChange, keydown: function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter") ) { return null } return _vm.switchValue($event) } } }), _vm.inactiveIconClass || _vm.inactiveText ? _c( "span", { class: [ "el-switch__label", "el-switch__label--left", !_vm.checked ? "is-active" : "" ] }, [ _vm.inactiveIconClass ? _c("i", { class: [_vm.inactiveIconClass] }) : _vm._e(), !_vm.inactiveIconClass && _vm.inactiveText ? _c("span", { attrs: { "aria-hidden": _vm.checked } }, [ _vm._v(_vm._s(_vm.inactiveText)) ]) : _vm._e() ] ) : _vm._e(), _c("span", { ref: "core", staticClass: "el-switch__core", style: { width: _vm.coreWidth + "px" } }), _vm.activeIconClass || _vm.activeText ? _c( "span", { class: [ "el-switch__label", "el-switch__label--right", _vm.checked ? "is-active" : "" ] }, [ _vm.activeIconClass ? _c("i", { class: [_vm.activeIconClass] }) : _vm._e(), !_vm.activeIconClass && _vm.activeText ? _c("span", { attrs: { "aria-hidden": !_vm.checked } }, [ _vm._v(_vm._s(_vm.activeText)) ]) : _vm._e() ] ) : _vm._e() ] ) } var componentvue_type_template_id_2dcd8fbb_staticRenderFns = [] componentvue_type_template_id_2dcd8fbb_render._withStripped = true // CONCATENATED MODULE: ./packages/switch/src/component.vue?vue&type=template&id=2dcd8fbb& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/switch/src/component.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var switch_src_componentvue_type_script_lang_js_ = ({ name: 'ElSwitch', mixins: [focus_default()('input'), migrating_default.a, emitter_default.a], inject: { elForm: { default: '' } }, props: { value: { type: [Boolean, String, Number], default: false }, disabled: { type: Boolean, default: false }, width: { type: Number, default: 40 }, activeIconClass: { type: String, default: '' }, inactiveIconClass: { type: String, default: '' }, activeText: String, inactiveText: String, activeColor: { type: String, default: '' }, inactiveColor: { type: String, default: '' }, activeValue: { type: [Boolean, String, Number], default: true }, inactiveValue: { type: [Boolean, String, Number], default: false }, name: { type: String, default: '' }, validateEvent: { type: Boolean, default: true }, id: String }, data: function data() { return { coreWidth: this.width }; }, created: function created() { if (!~[this.activeValue, this.inactiveValue].indexOf(this.value)) { this.$emit('input', this.inactiveValue); } }, computed: { checked: function checked() { return this.value === this.activeValue; }, switchDisabled: function switchDisabled() { return this.disabled || (this.elForm || {}).disabled; } }, watch: { checked: function checked() { this.$refs.input.checked = this.checked; if (this.activeColor || this.inactiveColor) { this.setBackgroundColor(); } if (this.validateEvent) { this.dispatch('ElFormItem', 'el.form.change', [this.value]); } } }, methods: { handleChange: function handleChange(event) { var _this = this; var val = this.checked ? this.inactiveValue : this.activeValue; this.$emit('input', val); this.$emit('change', val); this.$nextTick(function () { // set input's checked property // in case parent refuses to change component's value _this.$refs.input.checked = _this.checked; }); }, setBackgroundColor: function setBackgroundColor() { var newColor = this.checked ? this.activeColor : this.inactiveColor; this.$refs.core.style.borderColor = newColor; this.$refs.core.style.backgroundColor = newColor; }, switchValue: function switchValue() { !this.switchDisabled && this.handleChange(); }, getMigratingConfig: function getMigratingConfig() { return { props: { 'on-color': 'on-color is renamed to active-color.', 'off-color': 'off-color is renamed to inactive-color.', 'on-text': 'on-text is renamed to active-text.', 'off-text': 'off-text is renamed to inactive-text.', 'on-value': 'on-value is renamed to active-value.', 'off-value': 'off-value is renamed to inactive-value.', 'on-icon-class': 'on-icon-class is renamed to active-icon-class.', 'off-icon-class': 'off-icon-class is renamed to inactive-icon-class.' } }; } }, mounted: function mounted() { /* istanbul ignore if */ this.coreWidth = this.width || 40; if (this.activeColor || this.inactiveColor) { this.setBackgroundColor(); } this.$refs.input.checked = this.checked; } }); // CONCATENATED MODULE: ./packages/switch/src/component.vue?vue&type=script&lang=js& /* harmony default export */ var packages_switch_src_componentvue_type_script_lang_js_ = (switch_src_componentvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/switch/src/component.vue /* normalize component */ var src_component_component = normalizeComponent( packages_switch_src_componentvue_type_script_lang_js_, componentvue_type_template_id_2dcd8fbb_render, componentvue_type_template_id_2dcd8fbb_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var src_component_api; } src_component_component.options.__file = "packages/switch/src/component.vue" /* harmony default export */ var switch_src_component = (src_component_component.exports); // CONCATENATED MODULE: ./packages/switch/index.js /* istanbul ignore next */ switch_src_component.install = function (Vue) { Vue.component(switch_src_component.name, switch_src_component); }; /* harmony default export */ var packages_switch = (switch_src_component); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select.vue?vue&type=template&id=0e4aade6& var selectvue_type_template_id_0e4aade6_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: _vm.handleClose, expression: "handleClose" } ], staticClass: "el-select", class: [_vm.selectSize ? "el-select--" + _vm.selectSize : ""], on: { click: function($event) { $event.stopPropagation() return _vm.toggleMenu($event) } } }, [ _vm.multiple ? _c( "div", { ref: "tags", staticClass: "el-select__tags", style: { "max-width": _vm.inputWidth - 32 + "px", width: "100%" } }, [ _vm.collapseTags && _vm.selected.length ? _c( "span", [ _c( "el-tag", { attrs: { closable: !_vm.selectDisabled, size: _vm.collapseTagSize, hit: _vm.selected[0].hitState, type: "info", "disable-transitions": "" }, on: { close: function($event) { _vm.deleteTag($event, _vm.selected[0]) } } }, [ _c("span", { staticClass: "el-select__tags-text" }, [ _vm._v(_vm._s(_vm.selected[0].currentLabel)) ]) ] ), _vm.selected.length > 1 ? _c( "el-tag", { attrs: { closable: false, size: _vm.collapseTagSize, type: "info", "disable-transitions": "" } }, [ _c( "span", { staticClass: "el-select__tags-text" }, [_vm._v("+ " + _vm._s(_vm.selected.length - 1))] ) ] ) : _vm._e() ], 1 ) : _vm._e(), !_vm.collapseTags ? _c( "transition-group", { on: { "after-leave": _vm.resetInputHeight } }, _vm._l(_vm.selected, function(item) { return _c( "el-tag", { key: _vm.getValueKey(item), attrs: { closable: !_vm.selectDisabled, size: _vm.collapseTagSize, hit: item.hitState, type: "info", "disable-transitions": "" }, on: { close: function($event) { _vm.deleteTag($event, item) } } }, [ _c("span", { staticClass: "el-select__tags-text" }, [ _vm._v(_vm._s(item.currentLabel)) ]) ] ) }), 1 ) : _vm._e(), _vm.filterable ? _c("input", { directives: [ { name: "model", rawName: "v-model", value: _vm.query, expression: "query" } ], ref: "input", staticClass: "el-select__input", class: [_vm.selectSize ? "is-" + _vm.selectSize : ""], style: { "flex-grow": "1", width: _vm.inputLength / (_vm.inputWidth - 32) + "%", "max-width": _vm.inputWidth - 42 + "px" }, attrs: { type: "text", disabled: _vm.selectDisabled, autocomplete: _vm.autoComplete || _vm.autocomplete }, domProps: { value: _vm.query }, on: { focus: _vm.handleFocus, blur: function($event) { _vm.softFocus = false }, keyup: _vm.managePlaceholder, keydown: [ _vm.resetInputState, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "down", 40, $event.key, [ "Down", "ArrowDown" ]) ) { return null } $event.preventDefault() _vm.navigateOptions("next") }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "up", 38, $event.key, [ "Up", "ArrowUp" ]) ) { return null } $event.preventDefault() _vm.navigateOptions("prev") }, function($event) { if ( !("button" in $event) && _vm._k( $event.keyCode, "enter", 13, $event.key, "Enter" ) ) { return null } $event.preventDefault() return _vm.selectOption($event) }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "esc", 27, $event.key, [ "Esc", "Escape" ]) ) { return null } $event.stopPropagation() $event.preventDefault() _vm.visible = false }, function($event) { if ( !("button" in $event) && _vm._k( $event.keyCode, "delete", [8, 46], $event.key, ["Backspace", "Delete", "Del"] ) ) { return null } return _vm.deletePrevTag($event) }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "tab", 9, $event.key, "Tab") ) { return null } _vm.visible = false } ], compositionstart: _vm.handleComposition, compositionupdate: _vm.handleComposition, compositionend: _vm.handleComposition, input: [ function($event) { if ($event.target.composing) { return } _vm.query = $event.target.value }, _vm.debouncedQueryChange ] } }) : _vm._e() ], 1 ) : _vm._e(), _c( "el-input", { ref: "reference", class: { "is-focus": _vm.visible }, attrs: { type: "text", placeholder: _vm.currentPlaceholder, name: _vm.name, id: _vm.id, autocomplete: _vm.autoComplete || _vm.autocomplete, size: _vm.selectSize, disabled: _vm.selectDisabled, readonly: _vm.readonly, "validate-event": false, tabindex: _vm.multiple && _vm.filterable ? "-1" : null }, on: { focus: _vm.handleFocus, blur: _vm.handleBlur }, nativeOn: { keyup: function($event) { return _vm.debouncedOnInputChange($event) }, keydown: [ function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "down", 40, $event.key, [ "Down", "ArrowDown" ]) ) { return null } $event.stopPropagation() $event.preventDefault() _vm.navigateOptions("next") }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "up", 38, $event.key, [ "Up", "ArrowUp" ]) ) { return null } $event.stopPropagation() $event.preventDefault() _vm.navigateOptions("prev") }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter") ) { return null } $event.preventDefault() return _vm.selectOption($event) }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "esc", 27, $event.key, [ "Esc", "Escape" ]) ) { return null } $event.stopPropagation() $event.preventDefault() _vm.visible = false }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "tab", 9, $event.key, "Tab") ) { return null } _vm.visible = false } ], paste: function($event) { return _vm.debouncedOnInputChange($event) }, mouseenter: function($event) { _vm.inputHovering = true }, mouseleave: function($event) { _vm.inputHovering = false } }, model: { value: _vm.selectedLabel, callback: function($$v) { _vm.selectedLabel = $$v }, expression: "selectedLabel" } }, [ _vm.$slots.prefix ? _c("template", { slot: "prefix" }, [_vm._t("prefix")], 2) : _vm._e(), _c("template", { slot: "suffix" }, [ _c("i", { directives: [ { name: "show", rawName: "v-show", value: !_vm.showClose, expression: "!showClose" } ], class: [ "el-select__caret", "el-input__icon", "el-icon-" + _vm.iconClass ] }), _vm.showClose ? _c("i", { staticClass: "el-select__caret el-input__icon el-icon-circle-close", on: { click: _vm.handleClearClick } }) : _vm._e() ]) ], 2 ), _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "before-enter": _vm.handleMenuEnter, "after-leave": _vm.doDestroy } }, [ _c( "el-select-menu", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible && _vm.emptyText !== false, expression: "visible && emptyText !== false" } ], ref: "popper", attrs: { "append-to-body": _vm.popperAppendToBody } }, [ _c( "el-scrollbar", { directives: [ { name: "show", rawName: "v-show", value: _vm.options.length > 0 && !_vm.loading, expression: "options.length > 0 && !loading" } ], ref: "scrollbar", class: { "is-empty": !_vm.allowCreate && _vm.query && _vm.filteredOptionsCount === 0 }, attrs: { tag: "ul", "wrap-class": "el-select-dropdown__wrap", "view-class": "el-select-dropdown__list" } }, [ _vm.showNewOption ? _c("el-option", { attrs: { value: _vm.query, created: "" } }) : _vm._e(), _vm._t("default") ], 2 ), _vm.emptyText && (!_vm.allowCreate || _vm.loading || (_vm.allowCreate && _vm.options.length === 0)) ? [ _vm.$slots.empty ? _vm._t("empty") : _c("p", { staticClass: "el-select-dropdown__empty" }, [ _vm._v( "\n " + _vm._s(_vm.emptyText) + "\n " ) ]) ] : _vm._e() ], 2 ) ], 1 ) ], 1 ) } var selectvue_type_template_id_0e4aade6_staticRenderFns = [] selectvue_type_template_id_0e4aade6_render._withStripped = true // CONCATENATED MODULE: ./packages/select/src/select.vue?vue&type=template&id=0e4aade6& // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select-dropdown.vue?vue&type=template&id=06828748& var select_dropdownvue_type_template_id_06828748_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-select-dropdown el-popper", class: [{ "is-multiple": _vm.$parent.multiple }, _vm.popperClass], style: { minWidth: _vm.minWidth } }, [_vm._t("default")], 2 ) } var select_dropdownvue_type_template_id_06828748_staticRenderFns = [] select_dropdownvue_type_template_id_06828748_render._withStripped = true // CONCATENATED MODULE: ./packages/select/src/select-dropdown.vue?vue&type=template&id=06828748& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select-dropdown.vue?vue&type=script&lang=js& // // // // // // // // // /* harmony default export */ var select_dropdownvue_type_script_lang_js_ = ({ name: 'ElSelectDropdown', componentName: 'ElSelectDropdown', mixins: [vue_popper_default.a], props: { placement: { default: 'bottom-start' }, boundariesPadding: { default: 0 }, popperOptions: { default: function _default() { return { gpuAcceleration: false }; } }, visibleArrow: { default: true }, appendToBody: { type: Boolean, default: true } }, data: function data() { return { minWidth: '' }; }, computed: { popperClass: function popperClass() { return this.$parent.popperClass; } }, watch: { '$parent.inputWidth': function $parentInputWidth() { this.minWidth = this.$parent.$el.getBoundingClientRect().width + 'px'; } }, mounted: function mounted() { var _this = this; this.referenceElm = this.$parent.$refs.reference.$el; this.$parent.popperElm = this.popperElm = this.$el; this.$on('updatePopper', function () { if (_this.$parent.visible) _this.updatePopper(); }); this.$on('destroyPopper', this.destroyPopper); } }); // CONCATENATED MODULE: ./packages/select/src/select-dropdown.vue?vue&type=script&lang=js& /* harmony default export */ var src_select_dropdownvue_type_script_lang_js_ = (select_dropdownvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/select/src/select-dropdown.vue /* normalize component */ var select_dropdown_component = normalizeComponent( src_select_dropdownvue_type_script_lang_js_, select_dropdownvue_type_template_id_06828748_render, select_dropdownvue_type_template_id_06828748_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var select_dropdown_api; } select_dropdown_component.options.__file = "packages/select/src/select-dropdown.vue" /* harmony default export */ var select_dropdown = (select_dropdown_component.exports); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option.vue?vue&type=template&id=7a44c642& var optionvue_type_template_id_7a44c642_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "li", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-select-dropdown__item", class: { selected: _vm.itemSelected, "is-disabled": _vm.disabled || _vm.groupDisabled || _vm.limitReached, hover: _vm.hover }, on: { mouseenter: _vm.hoverItem, click: function($event) { $event.stopPropagation() return _vm.selectOptionClick($event) } } }, [_vm._t("default", [_c("span", [_vm._v(_vm._s(_vm.currentLabel))])])], 2 ) } var optionvue_type_template_id_7a44c642_staticRenderFns = [] optionvue_type_template_id_7a44c642_render._withStripped = true // CONCATENATED MODULE: ./packages/select/src/option.vue?vue&type=template&id=7a44c642& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option.vue?vue&type=script&lang=js& 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; }; // // // // // // // // // // // // // // // // // /* harmony default export */ var optionvue_type_script_lang_js_ = ({ mixins: [emitter_default.a], name: 'ElOption', componentName: 'ElOption', inject: ['select'], props: { value: { required: true }, label: [String, Number], created: Boolean, disabled: { type: Boolean, default: false } }, data: function data() { return { index: -1, groupDisabled: false, visible: true, hitState: false, hover: false }; }, computed: { isObject: function isObject() { return Object.prototype.toString.call(this.value).toLowerCase() === '[object object]'; }, currentLabel: function currentLabel() { return this.label || (this.isObject ? '' : this.value); }, currentValue: function currentValue() { return this.value || this.label || ''; }, itemSelected: function itemSelected() { if (!this.select.multiple) { return this.isEqual(this.value, this.select.value); } else { return this.contains(this.select.value, this.value); } }, limitReached: function limitReached() { if (this.select.multiple) { return !this.itemSelected && (this.select.value || []).length >= this.select.multipleLimit && this.select.multipleLimit > 0; } else { return false; } } }, watch: { currentLabel: function currentLabel() { if (!this.created && !this.select.remote) this.dispatch('ElSelect', 'setSelected'); }, value: function value(val, oldVal) { var _select = this.select, remote = _select.remote, valueKey = _select.valueKey; if (!this.created && !remote) { if (valueKey && (typeof val === 'undefined' ? 'undefined' : _typeof(val)) === 'object' && (typeof oldVal === 'undefined' ? 'undefined' : _typeof(oldVal)) === 'object' && val[valueKey] === oldVal[valueKey]) { return; } this.dispatch('ElSelect', 'setSelected'); } } }, methods: { isEqual: function isEqual(a, b) { if (!this.isObject) { return a === b; } else { var valueKey = this.select.valueKey; return Object(util_["getValueByPath"])(a, valueKey) === Object(util_["getValueByPath"])(b, valueKey); } }, contains: function contains() { var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; var target = arguments[1]; if (!this.isObject) { return arr && arr.indexOf(target) > -1; } else { var valueKey = this.select.valueKey; return arr && arr.some(function (item) { return Object(util_["getValueByPath"])(item, valueKey) === Object(util_["getValueByPath"])(target, valueKey); }); } }, handleGroupDisabled: function handleGroupDisabled(val) { this.groupDisabled = val; }, hoverItem: function hoverItem() { if (!this.disabled && !this.groupDisabled) { this.select.hoverIndex = this.select.options.indexOf(this); } }, selectOptionClick: function selectOptionClick() { if (this.disabled !== true && this.groupDisabled !== true) { this.dispatch('ElSelect', 'handleOptionClick', [this, true]); } }, queryChange: function queryChange(query) { this.visible = new RegExp(Object(util_["escapeRegexpString"])(query), 'i').test(this.currentLabel) || this.created; if (!this.visible) { this.select.filteredOptionsCount--; } } }, created: function created() { this.select.options.push(this); this.select.cachedOptions.push(this); this.select.optionsCount++; this.select.filteredOptionsCount++; this.$on('queryChange', this.queryChange); this.$on('handleGroupDisabled', this.handleGroupDisabled); }, beforeDestroy: function beforeDestroy() { var _select2 = this.select, selected = _select2.selected, multiple = _select2.multiple; var selectedOptions = multiple ? selected : [selected]; var index = this.select.cachedOptions.indexOf(this); var selectedIndex = selectedOptions.indexOf(this); // if option is not selected, remove it from cache if (index > -1 && selectedIndex < 0) { this.select.cachedOptions.splice(index, 1); } this.select.onOptionDestroy(this.select.options.indexOf(this)); } }); // CONCATENATED MODULE: ./packages/select/src/option.vue?vue&type=script&lang=js& /* harmony default export */ var src_optionvue_type_script_lang_js_ = (optionvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/select/src/option.vue /* normalize component */ var option_component = normalizeComponent( src_optionvue_type_script_lang_js_, optionvue_type_template_id_7a44c642_render, optionvue_type_template_id_7a44c642_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var option_api; } option_component.options.__file = "packages/select/src/option.vue" /* harmony default export */ var src_option = (option_component.exports); // EXTERNAL MODULE: external "element-ui/lib/tag" var tag_ = __webpack_require__(30); var tag_default = /*#__PURE__*/__webpack_require__.n(tag_); // EXTERNAL MODULE: external "element-ui/lib/utils/resize-event" var resize_event_ = __webpack_require__(13); // EXTERNAL MODULE: external "element-ui/lib/locale" var lib_locale_ = __webpack_require__(11); var lib_locale_default = /*#__PURE__*/__webpack_require__.n(lib_locale_); // EXTERNAL MODULE: external "element-ui/lib/utils/scroll-into-view" var scroll_into_view_ = __webpack_require__(27); var scroll_into_view_default = /*#__PURE__*/__webpack_require__.n(scroll_into_view_); // CONCATENATED MODULE: ./packages/select/src/navigation-mixin.js /* harmony default export */ var navigation_mixin = ({ data: function data() { return { hoverOption: -1 }; }, computed: { optionsAllDisabled: function optionsAllDisabled() { return this.options.filter(function (option) { return option.visible; }).every(function (option) { return option.disabled; }); } }, watch: { hoverIndex: function hoverIndex(val) { var _this = this; if (typeof val === 'number' && val > -1) { this.hoverOption = this.options[val] || {}; } this.options.forEach(function (option) { option.hover = _this.hoverOption === option; }); } }, methods: { navigateOptions: function navigateOptions(direction) { var _this2 = this; if (!this.visible) { this.visible = true; return; } if (this.options.length === 0 || this.filteredOptionsCount === 0) return; if (!this.optionsAllDisabled) { if (direction === 'next') { this.hoverIndex++; if (this.hoverIndex === this.options.length) { this.hoverIndex = 0; } } else if (direction === 'prev') { this.hoverIndex--; if (this.hoverIndex < 0) { this.hoverIndex = this.options.length - 1; } } var option = this.options[this.hoverIndex]; if (option.disabled === true || option.groupDisabled === true || !option.visible) { this.navigateOptions(direction); } this.$nextTick(function () { return _this2.scrollToOption(_this2.hoverOption); }); } } } }); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/select.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var selectvue_type_script_lang_js_ = ({ mixins: [emitter_default.a, locale_default.a, focus_default()('reference'), navigation_mixin], name: 'ElSelect', componentName: 'ElSelect', inject: { elForm: { default: '' }, elFormItem: { default: '' } }, provide: function provide() { return { 'select': this }; }, computed: { _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, readonly: function readonly() { return !this.filterable || this.multiple || !Object(util_["isIE"])() && !Object(util_["isEdge"])() && !this.visible; }, showClose: function showClose() { var hasValue = this.multiple ? Array.isArray(this.value) && this.value.length > 0 : this.value !== undefined && this.value !== null && this.value !== ''; var criteria = this.clearable && !this.selectDisabled && this.inputHovering && hasValue; return criteria; }, iconClass: function iconClass() { return this.remote && this.filterable ? '' : this.visible ? 'arrow-up is-reverse' : 'arrow-up'; }, debounce: function debounce() { return this.remote ? 300 : 0; }, emptyText: function emptyText() { if (this.loading) { return this.loadingText || this.t('el.select.loading'); } else { if (this.remote && this.query === '' && this.options.length === 0) return false; if (this.filterable && this.query && this.options.length > 0 && this.filteredOptionsCount === 0) { return this.noMatchText || this.t('el.select.noMatch'); } if (this.options.length === 0) { return this.noDataText || this.t('el.select.noData'); } } return null; }, showNewOption: function showNewOption() { var _this = this; var hasExistingOption = this.options.filter(function (option) { return !option.created; }).some(function (option) { return option.currentLabel === _this.query; }); return this.filterable && this.allowCreate && this.query !== '' && !hasExistingOption; }, selectSize: function selectSize() { return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; }, selectDisabled: function selectDisabled() { return this.disabled || (this.elForm || {}).disabled; }, collapseTagSize: function collapseTagSize() { return ['small', 'mini'].indexOf(this.selectSize) > -1 ? 'mini' : 'small'; } }, components: { ElInput: input_default.a, ElSelectMenu: select_dropdown, ElOption: src_option, ElTag: tag_default.a, ElScrollbar: scrollbar_default.a }, directives: { Clickoutside: clickoutside_default.a }, props: { name: String, id: String, value: { required: true }, autocomplete: { type: String, default: 'off' }, /** @Deprecated in next major version */ autoComplete: { type: String, validator: function validator(val) { false && false; return true; } }, automaticDropdown: Boolean, size: String, disabled: Boolean, clearable: Boolean, filterable: Boolean, allowCreate: Boolean, loading: Boolean, popperClass: String, remote: Boolean, loadingText: String, noMatchText: String, noDataText: String, remoteMethod: Function, filterMethod: Function, multiple: Boolean, multipleLimit: { type: Number, default: 0 }, placeholder: { type: String, default: function _default() { return Object(lib_locale_["t"])('el.select.placeholder'); } }, defaultFirstOption: Boolean, reserveKeyword: Boolean, valueKey: { type: String, default: 'value' }, collapseTags: Boolean, popperAppendToBody: { type: Boolean, default: true } }, data: function data() { return { options: [], cachedOptions: [], createdLabel: null, createdSelected: false, selected: this.multiple ? [] : {}, inputLength: 20, inputWidth: 0, initialInputHeight: 0, cachedPlaceHolder: '', optionsCount: 0, filteredOptionsCount: 0, visible: false, softFocus: false, selectedLabel: '', hoverIndex: -1, query: '', previousQuery: null, inputHovering: false, currentPlaceholder: '', menuVisibleOnFocus: false, isOnComposition: false, isSilentBlur: false }; }, watch: { selectDisabled: function selectDisabled() { var _this2 = this; this.$nextTick(function () { _this2.resetInputHeight(); }); }, placeholder: function placeholder(val) { this.cachedPlaceHolder = this.currentPlaceholder = val; }, value: function value(val, oldVal) { if (this.multiple) { this.resetInputHeight(); if (val && val.length > 0 || this.$refs.input && this.query !== '') { this.currentPlaceholder = ''; } else { this.currentPlaceholder = this.cachedPlaceHolder; } if (this.filterable && !this.reserveKeyword) { this.query = ''; this.handleQueryChange(this.query); } } this.setSelected(); if (this.filterable && !this.multiple) { this.inputLength = 20; } if (!Object(util_["valueEquals"])(val, oldVal)) { this.dispatch('ElFormItem', 'el.form.change', val); } }, visible: function visible(val) { var _this3 = this; if (!val) { this.broadcast('ElSelectDropdown', 'destroyPopper'); if (this.$refs.input) { this.$refs.input.blur(); } this.query = ''; this.previousQuery = null; this.selectedLabel = ''; this.inputLength = 20; this.menuVisibleOnFocus = false; this.resetHoverIndex(); this.$nextTick(function () { if (_this3.$refs.input && _this3.$refs.input.value === '' && _this3.selected.length === 0) { _this3.currentPlaceholder = _this3.cachedPlaceHolder; } }); if (!this.multiple) { if (this.selected) { if (this.filterable && this.allowCreate && this.createdSelected && this.createdLabel) { this.selectedLabel = this.createdLabel; } else { this.selectedLabel = this.selected.currentLabel; } if (this.filterable) this.query = this.selectedLabel; } if (this.filterable) { this.currentPlaceholder = this.cachedPlaceHolder; } } } else { this.broadcast('ElSelectDropdown', 'updatePopper'); if (this.filterable) { this.query = this.remote ? '' : this.selectedLabel; this.handleQueryChange(this.query); if (this.multiple) { this.$refs.input.focus(); } else { if (!this.remote) { this.broadcast('ElOption', 'queryChange', ''); this.broadcast('ElOptionGroup', 'queryChange'); } if (this.selectedLabel) { this.currentPlaceholder = this.selectedLabel; this.selectedLabel = ''; } } } } this.$emit('visible-change', val); }, options: function options() { var _this4 = this; if (this.$isServer) return; this.$nextTick(function () { _this4.broadcast('ElSelectDropdown', 'updatePopper'); }); if (this.multiple) { this.resetInputHeight(); } var inputs = this.$el.querySelectorAll('input'); if ([].indexOf.call(inputs, document.activeElement) === -1) { this.setSelected(); } if (this.defaultFirstOption && (this.filterable || this.remote) && this.filteredOptionsCount) { this.checkDefaultFirstOption(); } } }, methods: { handleComposition: function handleComposition(event) { var _this5 = this; var text = event.target.value; if (event.type === 'compositionend') { this.isOnComposition = false; this.$nextTick(function (_) { return _this5.handleQueryChange(text); }); } else { var lastCharacter = text[text.length - 1] || ''; this.isOnComposition = !Object(shared_["isKorean"])(lastCharacter); } }, handleQueryChange: function handleQueryChange(val) { var _this6 = this; if (this.previousQuery === val || this.isOnComposition) return; if (this.previousQuery === null && (typeof this.filterMethod === 'function' || typeof this.remoteMethod === 'function')) { this.previousQuery = val; return; } this.previousQuery = val; this.$nextTick(function () { if (_this6.visible) _this6.broadcast('ElSelectDropdown', 'updatePopper'); }); this.hoverIndex = -1; if (this.multiple && this.filterable) { this.$nextTick(function () { var length = _this6.$refs.input.value.length * 15 + 20; _this6.inputLength = _this6.collapseTags ? Math.min(50, length) : length; _this6.managePlaceholder(); _this6.resetInputHeight(); }); } if (this.remote && typeof this.remoteMethod === 'function') { this.hoverIndex = -1; this.remoteMethod(val); } else if (typeof this.filterMethod === 'function') { this.filterMethod(val); this.broadcast('ElOptionGroup', 'queryChange'); } else { this.filteredOptionsCount = this.optionsCount; this.broadcast('ElOption', 'queryChange', val); this.broadcast('ElOptionGroup', 'queryChange'); } if (this.defaultFirstOption && (this.filterable || this.remote) && this.filteredOptionsCount) { this.checkDefaultFirstOption(); } }, scrollToOption: function scrollToOption(option) { var target = Array.isArray(option) && option[0] ? option[0].$el : option.$el; if (this.$refs.popper && target) { var menu = this.$refs.popper.$el.querySelector('.el-select-dropdown__wrap'); scroll_into_view_default()(menu, target); } this.$refs.scrollbar && this.$refs.scrollbar.handleScroll(); }, handleMenuEnter: function handleMenuEnter() { var _this7 = this; this.$nextTick(function () { return _this7.scrollToOption(_this7.selected); }); }, emitChange: function emitChange(val) { if (!Object(util_["valueEquals"])(this.value, val)) { this.$emit('change', val); } }, getOption: function getOption(value) { var option = void 0; var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]'; var isNull = Object.prototype.toString.call(value).toLowerCase() === '[object null]'; var isUndefined = Object.prototype.toString.call(value).toLowerCase() === '[object undefined]'; for (var i = this.cachedOptions.length - 1; i >= 0; i--) { var cachedOption = this.cachedOptions[i]; var isEqual = isObject ? Object(util_["getValueByPath"])(cachedOption.value, this.valueKey) === Object(util_["getValueByPath"])(value, this.valueKey) : cachedOption.value === value; if (isEqual) { option = cachedOption; break; } } if (option) return option; var label = !isObject && !isNull && !isUndefined ? value : ''; var newOption = { value: value, currentLabel: label }; if (this.multiple) { newOption.hitState = false; } return newOption; }, setSelected: function setSelected() { var _this8 = this; if (!this.multiple) { var option = this.getOption(this.value); if (option.created) { this.createdLabel = option.currentLabel; this.createdSelected = true; } else { this.createdSelected = false; } this.selectedLabel = option.currentLabel; this.selected = option; if (this.filterable) this.query = this.selectedLabel; return; } var result = []; if (Array.isArray(this.value)) { this.value.forEach(function (value) { result.push(_this8.getOption(value)); }); } this.selected = result; this.$nextTick(function () { _this8.resetInputHeight(); }); }, handleFocus: function handleFocus(event) { if (!this.softFocus) { if (this.automaticDropdown || this.filterable) { this.visible = true; if (this.filterable) { this.menuVisibleOnFocus = true; } } this.$emit('focus', event); } else { this.softFocus = false; } }, blur: function blur() { this.visible = false; this.$refs.reference.blur(); }, handleBlur: function handleBlur(event) { var _this9 = this; setTimeout(function () { if (_this9.isSilentBlur) { _this9.isSilentBlur = false; } else { _this9.$emit('blur', event); } }, 50); this.softFocus = false; }, handleClearClick: function handleClearClick(event) { this.deleteSelected(event); }, doDestroy: function doDestroy() { this.$refs.popper && this.$refs.popper.doDestroy(); }, handleClose: function handleClose() { this.visible = false; }, toggleLastOptionHitState: function toggleLastOptionHitState(hit) { if (!Array.isArray(this.selected)) return; var option = this.selected[this.selected.length - 1]; if (!option) return; if (hit === true || hit === false) { option.hitState = hit; return hit; } option.hitState = !option.hitState; return option.hitState; }, deletePrevTag: function deletePrevTag(e) { if (e.target.value.length <= 0 && !this.toggleLastOptionHitState()) { var value = this.value.slice(); value.pop(); this.$emit('input', value); this.emitChange(value); } }, managePlaceholder: function managePlaceholder() { if (this.currentPlaceholder !== '') { this.currentPlaceholder = this.$refs.input.value ? '' : this.cachedPlaceHolder; } }, resetInputState: function resetInputState(e) { if (e.keyCode !== 8) this.toggleLastOptionHitState(false); this.inputLength = this.$refs.input.value.length * 15 + 20; this.resetInputHeight(); }, resetInputHeight: function resetInputHeight() { var _this10 = this; if (this.collapseTags && !this.filterable) return; this.$nextTick(function () { if (!_this10.$refs.reference) return; var inputChildNodes = _this10.$refs.reference.$el.childNodes; var input = [].filter.call(inputChildNodes, function (item) { return item.tagName === 'INPUT'; })[0]; var tags = _this10.$refs.tags; var sizeInMap = _this10.initialInputHeight || 40; input.style.height = _this10.selected.length === 0 ? sizeInMap + 'px' : Math.max(tags ? tags.clientHeight + (tags.clientHeight > sizeInMap ? 6 : 0) : 0, sizeInMap) + 'px'; if (_this10.visible && _this10.emptyText !== false) { _this10.broadcast('ElSelectDropdown', 'updatePopper'); } }); }, resetHoverIndex: function resetHoverIndex() { var _this11 = this; setTimeout(function () { if (!_this11.multiple) { _this11.hoverIndex = _this11.options.indexOf(_this11.selected); } else { if (_this11.selected.length > 0) { _this11.hoverIndex = Math.min.apply(null, _this11.selected.map(function (item) { return _this11.options.indexOf(item); })); } else { _this11.hoverIndex = -1; } } }, 300); }, handleOptionSelect: function handleOptionSelect(option, byClick) { var _this12 = this; if (this.multiple) { var value = (this.value || []).slice(); var optionIndex = this.getValueIndex(value, option.value); if (optionIndex > -1) { value.splice(optionIndex, 1); } else if (this.multipleLimit <= 0 || value.length < this.multipleLimit) { value.push(option.value); } this.$emit('input', value); this.emitChange(value); if (option.created) { this.query = ''; this.handleQueryChange(''); this.inputLength = 20; } if (this.filterable) this.$refs.input.focus(); } else { this.$emit('input', option.value); this.emitChange(option.value); this.visible = false; } this.isSilentBlur = byClick; this.setSoftFocus(); if (this.visible) return; this.$nextTick(function () { _this12.scrollToOption(option); }); }, setSoftFocus: function setSoftFocus() { this.softFocus = true; var input = this.$refs.input || this.$refs.reference; if (input) { input.focus(); } }, getValueIndex: function getValueIndex() { var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; var value = arguments[1]; var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]'; if (!isObject) { return arr.indexOf(value); } else { var valueKey = this.valueKey; var index = -1; arr.some(function (item, i) { if (Object(util_["getValueByPath"])(item, valueKey) === Object(util_["getValueByPath"])(value, valueKey)) { index = i; return true; } return false; }); return index; } }, toggleMenu: function toggleMenu() { if (!this.selectDisabled) { if (this.menuVisibleOnFocus) { this.menuVisibleOnFocus = false; } else { this.visible = !this.visible; } if (this.visible) { (this.$refs.input || this.$refs.reference).focus(); } } }, selectOption: function selectOption() { if (!this.visible) { this.toggleMenu(); } else { if (this.options[this.hoverIndex]) { this.handleOptionSelect(this.options[this.hoverIndex]); } } }, deleteSelected: function deleteSelected(event) { event.stopPropagation(); var value = this.multiple ? [] : ''; this.$emit('input', value); this.emitChange(value); this.visible = false; this.$emit('clear'); }, deleteTag: function deleteTag(event, tag) { var index = this.selected.indexOf(tag); if (index > -1 && !this.selectDisabled) { var value = this.value.slice(); value.splice(index, 1); this.$emit('input', value); this.emitChange(value); this.$emit('remove-tag', tag.value); } event.stopPropagation(); }, onInputChange: function onInputChange() { if (this.filterable && this.query !== this.selectedLabel) { this.query = this.selectedLabel; this.handleQueryChange(this.query); } }, onOptionDestroy: function onOptionDestroy(index) { if (index > -1) { this.optionsCount--; this.filteredOptionsCount--; this.options.splice(index, 1); } }, resetInputWidth: function resetInputWidth() { this.inputWidth = this.$refs.reference.$el.getBoundingClientRect().width; }, handleResize: function handleResize() { this.resetInputWidth(); if (this.multiple) this.resetInputHeight(); }, checkDefaultFirstOption: function checkDefaultFirstOption() { this.hoverIndex = -1; // highlight the created option var hasCreated = false; for (var i = this.options.length - 1; i >= 0; i--) { if (this.options[i].created) { hasCreated = true; this.hoverIndex = i; break; } } if (hasCreated) return; for (var _i = 0; _i !== this.options.length; ++_i) { var option = this.options[_i]; if (this.query) { // highlight first options that passes the filter if (!option.disabled && !option.groupDisabled && option.visible) { this.hoverIndex = _i; break; } } else { // highlight currently selected option if (option.itemSelected) { this.hoverIndex = _i; break; } } } }, getValueKey: function getValueKey(item) { if (Object.prototype.toString.call(item.value).toLowerCase() !== '[object object]') { return item.value; } else { return Object(util_["getValueByPath"])(item.value, this.valueKey); } } }, created: function created() { var _this13 = this; this.cachedPlaceHolder = this.currentPlaceholder = this.placeholder; if (this.multiple && !Array.isArray(this.value)) { this.$emit('input', []); } if (!this.multiple && Array.isArray(this.value)) { this.$emit('input', ''); } this.debouncedOnInputChange = debounce_default()(this.debounce, function () { _this13.onInputChange(); }); this.debouncedQueryChange = debounce_default()(this.debounce, function (e) { _this13.handleQueryChange(e.target.value); }); this.$on('handleOptionClick', this.handleOptionSelect); this.$on('setSelected', this.setSelected); }, mounted: function mounted() { var _this14 = this; if (this.multiple && Array.isArray(this.value) && this.value.length > 0) { this.currentPlaceholder = ''; } Object(resize_event_["addResizeListener"])(this.$el, this.handleResize); var reference = this.$refs.reference; if (reference && reference.$el) { var sizeMap = { medium: 36, small: 32, mini: 28 }; var input = reference.$el.querySelector('input'); this.initialInputHeight = input.getBoundingClientRect().height || sizeMap[this.selectSize]; } if (this.remote && this.multiple) { this.resetInputHeight(); } this.$nextTick(function () { if (reference && reference.$el) { _this14.inputWidth = reference.$el.getBoundingClientRect().width; } }); this.setSelected(); }, beforeDestroy: function beforeDestroy() { if (this.$el && this.handleResize) Object(resize_event_["removeResizeListener"])(this.$el, this.handleResize); } }); // CONCATENATED MODULE: ./packages/select/src/select.vue?vue&type=script&lang=js& /* harmony default export */ var src_selectvue_type_script_lang_js_ = (selectvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/select/src/select.vue /* normalize component */ var select_component = normalizeComponent( src_selectvue_type_script_lang_js_, selectvue_type_template_id_0e4aade6_render, selectvue_type_template_id_0e4aade6_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var select_api; } select_component.options.__file = "packages/select/src/select.vue" /* harmony default export */ var src_select = (select_component.exports); // CONCATENATED MODULE: ./packages/select/index.js /* istanbul ignore next */ src_select.install = function (Vue) { Vue.component(src_select.name, src_select); }; /* harmony default export */ var packages_select = (src_select); // CONCATENATED MODULE: ./packages/option/index.js /* istanbul ignore next */ src_option.install = function (Vue) { Vue.component(src_option.name, src_option); }; /* harmony default export */ var packages_option = (src_option); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option-group.vue?vue&type=template&id=6685e5de& var option_groupvue_type_template_id_6685e5de_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "ul", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-select-group__wrap" }, [ _c("li", { staticClass: "el-select-group__title" }, [ _vm._v(_vm._s(_vm.label)) ]), _c("li", [ _c("ul", { staticClass: "el-select-group" }, [_vm._t("default")], 2) ]) ] ) } var option_groupvue_type_template_id_6685e5de_staticRenderFns = [] option_groupvue_type_template_id_6685e5de_render._withStripped = true // CONCATENATED MODULE: ./packages/select/src/option-group.vue?vue&type=template&id=6685e5de& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/select/src/option-group.vue?vue&type=script&lang=js& // // // // // // // // // // // /* harmony default export */ var option_groupvue_type_script_lang_js_ = ({ mixins: [emitter_default.a], name: 'ElOptionGroup', componentName: 'ElOptionGroup', props: { label: String, disabled: { type: Boolean, default: false } }, data: function data() { return { visible: true }; }, watch: { disabled: function disabled(val) { this.broadcast('ElOption', 'handleGroupDisabled', val); } }, methods: { queryChange: function queryChange() { this.visible = this.$children && Array.isArray(this.$children) && this.$children.some(function (option) { return option.visible === true; }); } }, created: function created() { this.$on('queryChange', this.queryChange); }, mounted: function mounted() { if (this.disabled) { this.broadcast('ElOption', 'handleGroupDisabled', this.disabled); } } }); // CONCATENATED MODULE: ./packages/select/src/option-group.vue?vue&type=script&lang=js& /* harmony default export */ var src_option_groupvue_type_script_lang_js_ = (option_groupvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/select/src/option-group.vue /* normalize component */ var option_group_component = normalizeComponent( src_option_groupvue_type_script_lang_js_, option_groupvue_type_template_id_6685e5de_render, option_groupvue_type_template_id_6685e5de_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var option_group_api; } option_group_component.options.__file = "packages/select/src/option-group.vue" /* harmony default export */ var option_group = (option_group_component.exports); // CONCATENATED MODULE: ./packages/option-group/index.js /* istanbul ignore next */ option_group.install = function (Vue) { Vue.component(option_group.name, option_group); }; /* harmony default export */ var packages_option_group = (option_group); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button.vue?vue&type=template&id=ca859fb4& var buttonvue_type_template_id_ca859fb4_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "button", { staticClass: "el-button", class: [ _vm.type ? "el-button--" + _vm.type : "", _vm.buttonSize ? "el-button--" + _vm.buttonSize : "", { "is-disabled": _vm.buttonDisabled, "is-loading": _vm.loading, "is-plain": _vm.plain, "is-round": _vm.round, "is-circle": _vm.circle } ], attrs: { disabled: _vm.buttonDisabled || _vm.loading, autofocus: _vm.autofocus, type: _vm.nativeType }, on: { click: _vm.handleClick } }, [ _vm.loading ? _c("i", { staticClass: "el-icon-loading" }) : _vm._e(), _vm.icon && !_vm.loading ? _c("i", { class: _vm.icon }) : _vm._e(), _vm.$slots.default ? _c("span", [_vm._t("default")], 2) : _vm._e() ] ) } var buttonvue_type_template_id_ca859fb4_staticRenderFns = [] buttonvue_type_template_id_ca859fb4_render._withStripped = true // CONCATENATED MODULE: ./packages/button/src/button.vue?vue&type=template&id=ca859fb4& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var buttonvue_type_script_lang_js_ = ({ name: 'ElButton', inject: { elForm: { default: '' }, elFormItem: { default: '' } }, props: { type: { type: String, default: 'default' }, size: String, icon: { type: String, default: '' }, nativeType: { type: String, default: 'button' }, loading: Boolean, disabled: Boolean, plain: Boolean, autofocus: Boolean, round: Boolean, circle: Boolean }, computed: { _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, buttonSize: function buttonSize() { return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; }, buttonDisabled: function buttonDisabled() { return this.disabled || (this.elForm || {}).disabled; } }, methods: { handleClick: function handleClick(evt) { this.$emit('click', evt); } } }); // CONCATENATED MODULE: ./packages/button/src/button.vue?vue&type=script&lang=js& /* harmony default export */ var src_buttonvue_type_script_lang_js_ = (buttonvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/button/src/button.vue /* normalize component */ var button_component = normalizeComponent( src_buttonvue_type_script_lang_js_, buttonvue_type_template_id_ca859fb4_render, buttonvue_type_template_id_ca859fb4_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var button_api; } button_component.options.__file = "packages/button/src/button.vue" /* harmony default export */ var src_button = (button_component.exports); // CONCATENATED MODULE: ./packages/button/index.js /* istanbul ignore next */ src_button.install = function (Vue) { Vue.component(src_button.name, src_button); }; /* harmony default export */ var packages_button = (src_button); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button-group.vue?vue&type=template&id=3d8661d0& var button_groupvue_type_template_id_3d8661d0_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("div", { staticClass: "el-button-group" }, [_vm._t("default")], 2) } var button_groupvue_type_template_id_3d8661d0_staticRenderFns = [] button_groupvue_type_template_id_3d8661d0_render._withStripped = true // CONCATENATED MODULE: ./packages/button/src/button-group.vue?vue&type=template&id=3d8661d0& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/button/src/button-group.vue?vue&type=script&lang=js& // // // // // /* harmony default export */ var button_groupvue_type_script_lang_js_ = ({ name: 'ElButtonGroup' }); // CONCATENATED MODULE: ./packages/button/src/button-group.vue?vue&type=script&lang=js& /* harmony default export */ var src_button_groupvue_type_script_lang_js_ = (button_groupvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/button/src/button-group.vue /* normalize component */ var button_group_component = normalizeComponent( src_button_groupvue_type_script_lang_js_, button_groupvue_type_template_id_3d8661d0_render, button_groupvue_type_template_id_3d8661d0_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var button_group_api; } button_group_component.options.__file = "packages/button/src/button-group.vue" /* harmony default export */ var button_group = (button_group_component.exports); // CONCATENATED MODULE: ./packages/button-group/index.js /* istanbul ignore next */ button_group.install = function (Vue) { Vue.component(button_group.name, button_group); }; /* harmony default export */ var packages_button_group = (button_group); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/table/src/table.vue?vue&type=template&id=493fe34e& var tablevue_type_template_id_493fe34e_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-table", class: [ { "el-table--fit": _vm.fit, "el-table--striped": _vm.stripe, "el-table--border": _vm.border || _vm.isGroup, "el-table--hidden": _vm.isHidden, "el-table--group": _vm.isGroup, "el-table--fluid-height": _vm.maxHeight, "el-table--scrollable-x": _vm.layout.scrollX, "el-table--scrollable-y": _vm.layout.scrollY, "el-table--enable-row-hover": !_vm.store.states.isComplex, "el-table--enable-row-transition": (_vm.store.states.data || []).length !== 0 && (_vm.store.states.data || []).length < 100 }, _vm.tableSize ? "el-table--" + _vm.tableSize : "" ], on: { mouseleave: function($event) { _vm.handleMouseLeave($event) } } }, [ _c( "div", { ref: "hiddenColumns", staticClass: "hidden-columns" }, [_vm._t("default")], 2 ), _vm.showHeader ? _c( "div", { directives: [ { name: "mousewheel", rawName: "v-mousewheel", value: _vm.handleHeaderFooterMousewheel, expression: "handleHeaderFooterMousewheel" } ], ref: "headerWrapper", staticClass: "el-table__header-wrapper" }, [ _c("table-header", { ref: "tableHeader", style: { width: _vm.layout.bodyWidth ? _vm.layout.bodyWidth + "px" : "" }, attrs: { store: _vm.store, border: _vm.border, "default-sort": _vm.defaultSort } }) ], 1 ) : _vm._e(), _c( "div", { ref: "bodyWrapper", staticClass: "el-table__body-wrapper", class: [ _vm.layout.scrollX ? "is-scrolling-" + _vm.scrollPosition : "is-scrolling-none" ], style: [_vm.bodyHeight] }, [ _c("table-body", { style: { width: _vm.bodyWidth }, attrs: { context: _vm.context, store: _vm.store, stripe: _vm.stripe, "row-class-name": _vm.rowClassName, "row-style": _vm.rowStyle, highlight: _vm.highlightCurrentRow } }), !_vm.data || _vm.data.length === 0 ? _c( "div", { ref: "emptyBlock", staticClass: "el-table__empty-block", style: _vm.emptyBlockStyle }, [ _c( "span", { staticClass: "el-table__empty-text" }, [ _vm._t("empty", [ _vm._v( _vm._s(_vm.emptyText || _vm.t("el.table.emptyText")) ) ]) ], 2 ) ] ) : _vm._e(), _vm.$slots.append ? _c( "div", { ref: "appendWrapper", staticClass: "el-table__append-wrapper" }, [_vm._t("append")], 2 ) : _vm._e() ], 1 ), _vm.showSummary ? _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.data && _vm.data.length > 0, expression: "data && data.length > 0" }, { name: "mousewheel", rawName: "v-mousewheel", value: _vm.handleHeaderFooterMousewheel, expression: "handleHeaderFooterMousewheel" } ], ref: "footerWrapper", staticClass: "el-table__footer-wrapper" }, [ _c("table-footer", { style: { width: _vm.layout.bodyWidth ? _vm.layout.bodyWidth + "px" : "" }, attrs: { store: _vm.store, border: _vm.border, "sum-text": _vm.sumText || _vm.t("el.table.sumText"), "summary-method": _vm.summaryMethod, "default-sort": _vm.defaultSort } }) ], 1 ) : _vm._e(), _vm.fixedColumns.length > 0 ? _c( "div", { directives: [ { name: "mousewheel", rawName: "v-mousewheel", value: _vm.handleFixedMousewheel, expression: "handleFixedMousewheel" } ], ref: "fixedWrapper", staticClass: "el-table__fixed", style: [ { width: _vm.layout.fixedWidth ? _vm.layout.fixedWidth + "px" : "" }, _vm.fixedHeight ] }, [ _vm.showHeader ? _c( "div", { ref: "fixedHeaderWrapper", staticClass: "el-table__fixed-header-wrapper" }, [ _c("table-header", { ref: "fixedTableHeader", style: { width: _vm.bodyWidth }, attrs: { fixed: "left", border: _vm.border, store: _vm.store } }) ], 1 ) : _vm._e(), _c( "div", { ref: "fixedBodyWrapper", staticClass: "el-table__fixed-body-wrapper", style: [ { top: _vm.layout.headerHeight + "px" }, _vm.fixedBodyHeight ] }, [ _c("table-body", { style: { width: _vm.bodyWidth }, attrs: { fixed: "left", store: _vm.store, stripe: _vm.stripe, highlight: _vm.highlightCurrentRow, "row-class-name": _vm.rowClassName, "row-style": _vm.rowStyle } }), _vm.$slots.append ? _c("div", { staticClass: "el-table__append-gutter", style: { height: _vm.layout.appendHeight + "px" } }) : _vm._e() ], 1 ), _vm.showSummary ? _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.data && _vm.data.length > 0, expression: "data && data.length > 0" } ], ref: "fixedFooterWrapper", staticClass: "el-table__fixed-footer-wrapper" }, [ _c("table-footer", { style: { width: _vm.bodyWidth }, attrs: { fixed: "left", border: _vm.border, "sum-text": _vm.sumText || _vm.t("el.table.sumText"), "summary-method": _vm.summaryMethod, store: _vm.store } }) ], 1 ) : _vm._e() ] ) : _vm._e(), _vm.rightFixedColumns.length > 0 ? _c( "div", { directives: [ { name: "mousewheel", rawName: "v-mousewheel", value: _vm.handleFixedMousewheel, expression: "handleFixedMousewheel" } ], ref: "rightFixedWrapper", staticClass: "el-table__fixed-right", style: [ { width: _vm.layout.rightFixedWidth ? _vm.layout.rightFixedWidth + "px" : "", right: _vm.layout.scrollY ? (_vm.border ? _vm.layout.gutterWidth : _vm.layout.gutterWidth || 0) + "px" : "" }, _vm.fixedHeight ] }, [ _vm.showHeader ? _c( "div", { ref: "rightFixedHeaderWrapper", staticClass: "el-table__fixed-header-wrapper" }, [ _c("table-header", { ref: "rightFixedTableHeader", style: { width: _vm.bodyWidth }, attrs: { fixed: "right", border: _vm.border, store: _vm.store } }) ], 1 ) : _vm._e(), _c( "div", { ref: "rightFixedBodyWrapper", staticClass: "el-table__fixed-body-wrapper", style: [ { top: _vm.layout.headerHeight + "px" }, _vm.fixedBodyHeight ] }, [ _c("table-body", { style: { width: _vm.bodyWidth }, attrs: { fixed: "right", store: _vm.store, stripe: _vm.stripe, "row-class-name": _vm.rowClassName, "row-style": _vm.rowStyle, highlight: _vm.highlightCurrentRow } }), _vm.$slots.append ? _c("div", { staticClass: "el-table__append-gutter", style: { height: _vm.layout.appendHeight + "px" } }) : _vm._e() ], 1 ), _vm.showSummary ? _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.data && _vm.data.length > 0, expression: "data && data.length > 0" } ], ref: "rightFixedFooterWrapper", staticClass: "el-table__fixed-footer-wrapper" }, [ _c("table-footer", { style: { width: _vm.bodyWidth }, attrs: { fixed: "right", border: _vm.border, "sum-text": _vm.sumText || _vm.t("el.table.sumText"), "summary-method": _vm.summaryMethod, store: _vm.store } }) ], 1 ) : _vm._e() ] ) : _vm._e(), _vm.rightFixedColumns.length > 0 ? _c("div", { ref: "rightFixedPatch", staticClass: "el-table__fixed-right-patch", style: { width: _vm.layout.scrollY ? _vm.layout.gutterWidth + "px" : "0", height: _vm.layout.headerHeight + "px" } }) : _vm._e(), _c("div", { directives: [ { name: "show", rawName: "v-show", value: _vm.resizeProxyVisible, expression: "resizeProxyVisible" } ], ref: "resizeProxy", staticClass: "el-table__column-resize-proxy" }) ] ) } var tablevue_type_template_id_493fe34e_staticRenderFns = [] tablevue_type_template_id_493fe34e_render._withStripped = true // CONCATENATED MODULE: ./packages/table/src/table.vue?vue&type=template&id=493fe34e& // EXTERNAL MODULE: external "element-ui/lib/checkbox" var checkbox_ = __webpack_require__(16); var checkbox_default = /*#__PURE__*/__webpack_require__.n(checkbox_); // EXTERNAL MODULE: external "throttle-debounce" var external_throttle_debounce_ = __webpack_require__(35); // EXTERNAL MODULE: external "normalize-wheel" var external_normalize_wheel_ = __webpack_require__(38); var external_normalize_wheel_default = /*#__PURE__*/__webpack_require__.n(external_normalize_wheel_); // CONCATENATED MODULE: ./src/directives/mousewheel.js var isFirefox = typeof navigator !== 'undefined' && navigator.userAgent.toLowerCase().indexOf('firefox') > -1; var mousewheel_mousewheel = function mousewheel(element, callback) { if (element && element.addEventListener) { element.addEventListener(isFirefox ? 'DOMMouseScroll' : 'mousewheel', function (event) { var normalized = external_normalize_wheel_default()(event); callback && callback.apply(this, [event, normalized]); }); } }; /* harmony default export */ var directives_mousewheel = ({ bind: function bind(el, binding) { mousewheel_mousewheel(el, binding.value); } }); // EXTERNAL MODULE: external "vue" var external_vue_ = __webpack_require__(6); var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_); // CONCATENATED MODULE: ./packages/table/src/util.js var util_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; }; var getCell = function getCell(event) { var cell = event.target; while (cell && cell.tagName.toUpperCase() !== 'HTML') { if (cell.tagName.toUpperCase() === 'TD') { return cell; } cell = cell.parentNode; } return null; }; var util_isObject = function isObject(obj) { return obj !== null && (typeof obj === 'undefined' ? 'undefined' : util_typeof(obj)) === 'object'; }; var util_orderBy = function orderBy(array, sortKey, reverse, sortMethod, sortBy) { if (!sortKey && !sortMethod && (!sortBy || Array.isArray(sortBy) && !sortBy.length)) { return array; } if (typeof reverse === 'string') { reverse = reverse === 'descending' ? -1 : 1; } else { reverse = reverse && reverse < 0 ? -1 : 1; } var getKey = sortMethod ? null : function (value, index) { if (sortBy) { if (!Array.isArray(sortBy)) { sortBy = [sortBy]; } return sortBy.map(function (by) { if (typeof by === 'string') { return Object(util_["getValueByPath"])(value, by); } else { return by(value, index, array); } }); } if (sortKey !== '$key') { if (util_isObject(value) && '$value' in value) value = value.$value; } return [util_isObject(value) ? Object(util_["getValueByPath"])(value, sortKey) : value]; }; var compare = function compare(a, b) { if (sortMethod) { return sortMethod(a.value, b.value); } for (var i = 0, len = a.key.length; i < len; i++) { if (a.key[i] < b.key[i]) { return -1; } if (a.key[i] > b.key[i]) { return 1; } } return 0; }; return array.map(function (value, index) { return { value: value, index: index, key: getKey ? getKey(value, index) : null }; }).sort(function (a, b) { var order = compare(a, b); if (!order) { // make stable https://en.wikipedia.org/wiki/Sorting_algorithm#Stability order = a.index - b.index; } return order * reverse; }).map(function (item) { return item.value; }); }; var getColumnById = function getColumnById(table, columnId) { var column = null; table.columns.forEach(function (item) { if (item.id === columnId) { column = item; } }); return column; }; var getColumnByKey = function getColumnByKey(table, columnKey) { var column = null; for (var i = 0; i < table.columns.length; i++) { var item = table.columns[i]; if (item.columnKey === columnKey) { column = item; break; } } return column; }; var getColumnByCell = function getColumnByCell(table, cell) { var matches = (cell.className || '').match(/el-table_[^\s]+/gm); if (matches) { return getColumnById(table, matches[0]); } return null; }; var getRowIdentity = function getRowIdentity(row, rowKey) { if (!row) throw new Error('row is required when get row identity'); if (typeof rowKey === 'string') { if (rowKey.indexOf('.') < 0) { return row[rowKey]; } var key = rowKey.split('.'); var current = row; for (var i = 0; i < key.length; i++) { current = current[key[i]]; } return current; } else if (typeof rowKey === 'function') { return rowKey.call(null, row); } }; var getKeysMap = function getKeysMap(array, rowKey) { var arrayMap = {}; (array || []).forEach(function (row, index) { arrayMap[getRowIdentity(row, rowKey)] = { row: row, index: index }; }); return arrayMap; }; function hasOwn(obj, key) { return Object.prototype.hasOwnProperty.call(obj, key); } function mergeOptions(defaults, config) { var options = {}; var key = void 0; for (key in defaults) { options[key] = defaults[key]; } for (key in config) { if (hasOwn(config, key)) { var value = config[key]; if (typeof value !== 'undefined') { options[key] = value; } } } return options; } function parseWidth(width) { if (width !== undefined) { width = parseInt(width, 10); if (isNaN(width)) { width = null; } } return width; } function parseMinWidth(minWidth) { if (typeof minWidth !== 'undefined') { minWidth = parseWidth(minWidth); if (isNaN(minWidth)) { minWidth = 80; } } return minWidth; }; function parseHeight(height) { if (typeof height === 'number') { return height; } if (typeof height === 'string') { if (/^\d+(?:px)?$/.test(height)) { return parseInt(height, 10); } else { return height; } } return null; } // https://github.com/reduxjs/redux/blob/master/src/compose.js function compose() { for (var _len = arguments.length, funcs = Array(_len), _key = 0; _key < _len; _key++) { funcs[_key] = arguments[_key]; } if (funcs.length === 0) { return function (arg) { return arg; }; } if (funcs.length === 1) { return funcs[0]; } return funcs.reduce(function (a, b) { return function () { return a(b.apply(undefined, arguments)); }; }); } function toggleRowStatus(statusArr, row, newVal) { var changed = false; var index = statusArr.indexOf(row); var included = index !== -1; var addRow = function addRow() { statusArr.push(row); changed = true; }; var removeRow = function removeRow() { statusArr.splice(index, 1); changed = true; }; if (typeof newVal === 'boolean') { if (newVal && !included) { addRow(); } else if (!newVal && included) { removeRow(); } } else { if (included) { removeRow(); } else { addRow(); } } return changed; } function walkTreeNode(root, cb) { var childrenKey = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'children'; var lazyKey = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'hasChildren'; var isNil = function isNil(array) { return !(Array.isArray(array) && array.length); }; function _walker(parent, children, level) { cb(parent, children, level); children.forEach(function (item) { if (item[lazyKey]) { cb(item, null, level + 1); return; } var children = item[childrenKey]; if (!isNil(children)) { _walker(item, children, level + 1); } }); } root.forEach(function (item) { if (item[lazyKey]) { cb(item, null, 0); return; } var children = item[childrenKey]; if (!isNil(children)) { _walker(item, children, 0); } }); } // CONCATENATED MODULE: ./packages/table/src/store/expand.js /* harmony default export */ var expand = ({ data: function data() { return { states: { defaultExpandAll: false, expandRows: [] } }; }, methods: { updateExpandRows: function updateExpandRows() { var _states = this.states, _states$data = _states.data, data = _states$data === undefined ? [] : _states$data, rowKey = _states.rowKey, defaultExpandAll = _states.defaultExpandAll, expandRows = _states.expandRows; if (defaultExpandAll) { this.states.expandRows = data.slice(); } else if (rowKey) { // TODO:这里的代码可以优化 var expandRowsMap = getKeysMap(expandRows, rowKey); this.states.expandRows = data.reduce(function (prev, row) { var rowId = getRowIdentity(row, rowKey); var rowInfo = expandRowsMap[rowId]; if (rowInfo) { prev.push(row); } return prev; }, []); } else { this.states.expandRows = []; } }, toggleRowExpansion: function toggleRowExpansion(row, expanded) { var changed = toggleRowStatus(this.states.expandRows, row, expanded); if (changed) { this.table.$emit('expand-change', row, this.states.expandRows.slice()); this.scheduleLayout(); } }, setExpandRowKeys: function setExpandRowKeys(rowKeys) { this.assertRowKey(); // TODO:这里的代码可以优化 var _states2 = this.states, data = _states2.data, rowKey = _states2.rowKey; var keysMap = getKeysMap(data, rowKey); this.states.expandRows = rowKeys.reduce(function (prev, cur) { var info = keysMap[cur]; if (info) { prev.push(info.row); } return prev; }, []); }, isRowExpanded: function isRowExpanded(row) { var _states3 = this.states, _states3$expandRows = _states3.expandRows, expandRows = _states3$expandRows === undefined ? [] : _states3$expandRows, rowKey = _states3.rowKey; if (rowKey) { var expandMap = getKeysMap(expandRows, rowKey); return !!expandMap[getRowIdentity(row, rowKey)]; } return expandRows.indexOf(row) !== -1; } } }); // CONCATENATED MODULE: ./packages/table/src/store/current.js /* harmony default export */ var current = ({ data: function data() { return { states: { // 不可响应的,设置 currentRowKey 时,data 不一定存在,也许无法算出正确的 currentRow // 把该值缓存一下,当用户点击修改 currentRow 时,把该值重置为 null _currentRowKey: null, currentRow: null } }; }, methods: { setCurrentRowKey: function setCurrentRowKey(key) { this.assertRowKey(); this.states._currentRowKey = key; this.setCurrentRowByKey(key); }, restoreCurrentRowKey: function restoreCurrentRowKey() { this.states._currentRowKey = null; }, setCurrentRowByKey: function setCurrentRowByKey(key) { var states = this.states; var _states$data = states.data, data = _states$data === undefined ? [] : _states$data, rowKey = states.rowKey; var currentRow = null; if (rowKey) { currentRow = Object(util_["arrayFind"])(data, function (item) { return getRowIdentity(item, rowKey) === key; }); } states.currentRow = currentRow; }, updateCurrentRow: function updateCurrentRow(currentRow) { var states = this.states, table = this.table; var oldCurrentRow = states.currentRow; if (currentRow && currentRow !== oldCurrentRow) { states.currentRow = currentRow; table.$emit('current-change', currentRow, oldCurrentRow); return; } if (!currentRow && oldCurrentRow) { states.currentRow = null; table.$emit('current-change', null, oldCurrentRow); } }, updateCurrentRowData: function updateCurrentRowData() { var states = this.states, table = this.table; var rowKey = states.rowKey, _currentRowKey = states._currentRowKey; // data 为 null 时,解构时的默认值会被忽略 var data = states.data || []; var oldCurrentRow = states.currentRow; // 当 currentRow 不在 data 中时尝试更新数据 if (data.indexOf(oldCurrentRow) === -1 && oldCurrentRow) { if (rowKey) { var currentRowKey = getRowIdentity(oldCurrentRow, rowKey); this.setCurrentRowByKey(currentRowKey); } else { states.currentRow = null; } if (states.currentRow === null) { table.$emit('current-change', null, oldCurrentRow); } } else if (_currentRowKey) { // 把初始时下设置的 rowKey 转化成 rowData this.setCurrentRowByKey(_currentRowKey); this.restoreCurrentRowKey(); } } } }); // CONCATENATED MODULE: ./packages/table/src/store/tree.js var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; /* harmony default export */ var tree = ({ data: function data() { return { states: { // defaultExpandAll 存在于 expand.js 中,这里不重复添加 // 在展开行中,expandRowKeys 会被转化成 expandRows,expandRowKeys 这个属性只是记录了 TreeTable 行的展开 // TODO: 拆分为独立的 TreeTable,统一用法 expandRowKeys: [], treeData: {}, indent: 16, lazy: false, lazyTreeNodeMap: {}, lazyColumnIdentifier: 'hasChildren', childrenColumnName: 'children' } }; }, computed: { // 嵌入型的数据,watch 无法是检测到变化 https://github.com/ElemeFE/element/issues/14998 // TODO: 使用 computed 解决该问题,是否会造成性能问题? // @return { id: { level, children } } normalizedData: function normalizedData() { if (!this.states.rowKey) return {}; var data = this.states.data || []; return this.normalize(data); }, // @return { id: { children } } // 针对懒加载的情形,不处理嵌套数据 normalizedLazyNode: function normalizedLazyNode() { var _states = this.states, rowKey = _states.rowKey, lazyTreeNodeMap = _states.lazyTreeNodeMap, lazyColumnIdentifier = _states.lazyColumnIdentifier; var keys = Object.keys(lazyTreeNodeMap); var res = {}; if (!keys.length) return res; keys.forEach(function (key) { if (lazyTreeNodeMap[key].length) { var item = { children: [] }; lazyTreeNodeMap[key].forEach(function (row) { var currentRowKey = getRowIdentity(row, rowKey); item.children.push(currentRowKey); if (row[lazyColumnIdentifier] && !res[currentRowKey]) { res[currentRowKey] = { children: [] }; } }); res[key] = item; } }); return res; } }, watch: { normalizedData: 'updateTreeData', normalizedLazyNode: 'updateTreeData' }, methods: { normalize: function normalize(data) { var _states2 = this.states, childrenColumnName = _states2.childrenColumnName, lazyColumnIdentifier = _states2.lazyColumnIdentifier, rowKey = _states2.rowKey, lazy = _states2.lazy; var res = {}; walkTreeNode(data, function (parent, children, level) { var parentId = getRowIdentity(parent, rowKey); if (Array.isArray(children)) { res[parentId] = { children: children.map(function (row) { return getRowIdentity(row, rowKey); }), level: level }; } else if (lazy) { // 当 children 不存在且 lazy 为 true,该节点即为懒加载的节点 res[parentId] = { children: [], lazy: true, level: level }; } }, childrenColumnName, lazyColumnIdentifier); return res; }, updateTreeData: function updateTreeData() { var nested = this.normalizedData; var normalizedLazyNode = this.normalizedLazyNode; var keys = Object.keys(nested); var newTreeData = {}; if (keys.length) { var _states3 = this.states, oldTreeData = _states3.treeData, defaultExpandAll = _states3.defaultExpandAll, expandRowKeys = _states3.expandRowKeys, lazy = _states3.lazy; var rootLazyRowKeys = []; var getExpanded = function getExpanded(oldValue, key) { var included = defaultExpandAll || expandRowKeys && expandRowKeys.indexOf(key) !== -1; return !!(oldValue && oldValue.expanded || included); }; // 合并 expanded 与 display,确保数据刷新后,状态不变 keys.forEach(function (key) { var oldValue = oldTreeData[key]; var newValue = _extends({}, nested[key]); newValue.expanded = getExpanded(oldValue, key); if (newValue.lazy) { var _ref = oldValue || {}, _ref$loaded = _ref.loaded, loaded = _ref$loaded === undefined ? false : _ref$loaded, _ref$loading = _ref.loading, loading = _ref$loading === undefined ? false : _ref$loading; newValue.loaded = !!loaded; newValue.loading = !!loading; rootLazyRowKeys.push(key); } newTreeData[key] = newValue; }); // 根据懒加载数据更新 treeData var lazyKeys = Object.keys(normalizedLazyNode); if (lazy && lazyKeys.length && rootLazyRowKeys.length) { lazyKeys.forEach(function (key) { var oldValue = oldTreeData[key]; var lazyNodeChildren = normalizedLazyNode[key].children; if (rootLazyRowKeys.indexOf(key) !== -1) { // 懒加载的 root 节点,更新一下原有的数据,原来的 children 一定是空数组 if (newTreeData[key].children.length !== 0) { throw new Error('[ElTable]children must be an empty array.'); } newTreeData[key].children = lazyNodeChildren; } else { var _ref2 = oldValue || {}, _ref2$loaded = _ref2.loaded, loaded = _ref2$loaded === undefined ? false : _ref2$loaded, _ref2$loading = _ref2.loading, loading = _ref2$loading === undefined ? false : _ref2$loading; newTreeData[key] = { lazy: true, loaded: !!loaded, loading: !!loading, expanded: getExpanded(oldValue, key), children: lazyNodeChildren, level: '' }; } }); } } this.states.treeData = newTreeData; this.updateTableScrollY(); }, updateTreeExpandKeys: function updateTreeExpandKeys(value) { this.states.expandRowKeys = value; this.updateTreeData(); }, toggleTreeExpansion: function toggleTreeExpansion(row, expanded) { this.assertRowKey(); var _states4 = this.states, rowKey = _states4.rowKey, treeData = _states4.treeData; var id = getRowIdentity(row, rowKey); var data = id && treeData[id]; if (id && data && 'expanded' in data) { var oldExpanded = data.expanded; expanded = typeof expanded === 'undefined' ? !data.expanded : expanded; treeData[id].expanded = expanded; if (oldExpanded !== expanded) { this.table.$emit('expand-change', row, expanded); } this.updateTableScrollY(); } }, loadOrToggle: function loadOrToggle(row) { this.assertRowKey(); var _states5 = this.states, lazy = _states5.lazy, treeData = _states5.treeData, rowKey = _states5.rowKey; var id = getRowIdentity(row, rowKey); var data = treeData[id]; if (lazy && data && 'loaded' in data && !data.loaded) { this.loadData(row, id, data); } else { this.toggleTreeExpansion(row); } }, loadData: function loadData(row, key, treeNode) { var _this = this; var load = this.table.load; var _states6 = this.states, lazyTreeNodeMap = _states6.lazyTreeNodeMap, treeData = _states6.treeData; if (load && !treeData[key].loaded) { treeData[key].loading = true; load(row, treeNode, function (data) { if (!Array.isArray(data)) { throw new Error('[ElTable] data must be an array'); } treeData[key].loading = false; treeData[key].loaded = true; treeData[key].expanded = true; if (data.length) { _this.$set(lazyTreeNodeMap, key, data); } _this.table.$emit('expand-change', row, true); }); } } } }); // CONCATENATED MODULE: ./packages/table/src/store/watcher.js var watcher_sortData = function sortData(data, states) { var sortingColumn = states.sortingColumn; if (!sortingColumn || typeof sortingColumn.sortable === 'string') { return data; } return util_orderBy(data, states.sortProp, states.sortOrder, sortingColumn.sortMethod, sortingColumn.sortBy); }; var doFlattenColumns = function doFlattenColumns(columns) { var result = []; columns.forEach(function (column) { if (column.children) { result.push.apply(result, doFlattenColumns(column.children)); } else { result.push(column); } }); return result; }; /* harmony default export */ var watcher = (external_vue_default.a.extend({ data: function data() { return { states: { // 3.0 版本后要求必须设置该属性 rowKey: null, // 渲染的数据来源,是对 table 中的 data 过滤排序后的结果 data: [], // 是否包含固定列 isComplex: false, // 列 _columns: [], // 不可响应的 originColumns: [], columns: [], fixedColumns: [], rightFixedColumns: [], leafColumns: [], fixedLeafColumns: [], rightFixedLeafColumns: [], leafColumnsLength: 0, fixedLeafColumnsLength: 0, rightFixedLeafColumnsLength: 0, // 选择 isAllSelected: false, selection: [], reserveSelection: false, selectOnIndeterminate: false, selectable: null, // 过滤 filters: {}, // 不可响应的 filteredData: null, // 排序 sortingColumn: null, sortProp: null, sortOrder: null, hoverRow: null } }; }, mixins: [expand, current, tree], methods: { // 检查 rowKey 是否存在 assertRowKey: function assertRowKey() { var rowKey = this.states.rowKey; if (!rowKey) throw new Error('[ElTable] prop row-key is required'); }, // 更新列 updateColumns: function updateColumns() { var states = this.states; var _columns = states._columns || []; states.fixedColumns = _columns.filter(function (column) { return column.fixed === true || column.fixed === 'left'; }); states.rightFixedColumns = _columns.filter(function (column) { return column.fixed === 'right'; }); if (states.fixedColumns.length > 0 && _columns[0] && _columns[0].type === 'selection' && !_columns[0].fixed) { _columns[0].fixed = true; states.fixedColumns.unshift(_columns[0]); } var notFixedColumns = _columns.filter(function (column) { return !column.fixed; }); states.originColumns = [].concat(states.fixedColumns).concat(notFixedColumns).concat(states.rightFixedColumns); var leafColumns = doFlattenColumns(notFixedColumns); var fixedLeafColumns = doFlattenColumns(states.fixedColumns); var rightFixedLeafColumns = doFlattenColumns(states.rightFixedColumns); states.leafColumnsLength = leafColumns.length; states.fixedLeafColumnsLength = fixedLeafColumns.length; states.rightFixedLeafColumnsLength = rightFixedLeafColumns.length; states.columns = [].concat(fixedLeafColumns).concat(leafColumns).concat(rightFixedLeafColumns); states.isComplex = states.fixedColumns.length > 0 || states.rightFixedColumns.length > 0; }, // 更新 DOM scheduleLayout: function scheduleLayout(needUpdateColumns) { if (needUpdateColumns) { this.updateColumns(); } this.table.debouncedUpdateLayout(); }, // 选择 isSelected: function isSelected(row) { var _states$selection = this.states.selection, selection = _states$selection === undefined ? [] : _states$selection; return selection.indexOf(row) > -1; }, clearSelection: function clearSelection() { var states = this.states; states.isAllSelected = false; var oldSelection = states.selection; if (oldSelection.length) { states.selection = []; this.table.$emit('selection-change', []); } }, cleanSelection: function cleanSelection() { var states = this.states; var data = states.data, rowKey = states.rowKey, selection = states.selection; var deleted = void 0; if (rowKey) { deleted = []; var selectedMap = getKeysMap(selection, rowKey); var dataMap = getKeysMap(data, rowKey); for (var key in selectedMap) { if (selectedMap.hasOwnProperty(key) && !dataMap[key]) { deleted.push(selectedMap[key].row); } } } else { deleted = selection.filter(function (item) { return data.indexOf(item) === -1; }); } if (deleted.length) { var newSelection = selection.filter(function (item) { return deleted.indexOf(item) === -1; }); states.selection = newSelection; this.table.$emit('selection-change', newSelection.slice()); } }, toggleRowSelection: function toggleRowSelection(row, selected) { var emitChange = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; var changed = toggleRowStatus(this.states.selection, row, selected); if (changed) { var newSelection = (this.states.selection || []).slice(); // 调用 API 修改选中值,不触发 select 事件 if (emitChange) { this.table.$emit('select', newSelection, row); } this.table.$emit('selection-change', newSelection); } }, _toggleAllSelection: function _toggleAllSelection() { var states = this.states; var _states$data = states.data, data = _states$data === undefined ? [] : _states$data, selection = states.selection; // when only some rows are selected (but not all), select or deselect all of them // depending on the value of selectOnIndeterminate var value = states.selectOnIndeterminate ? !states.isAllSelected : !(states.isAllSelected || selection.length); states.isAllSelected = value; var selectionChanged = false; data.forEach(function (row, index) { if (states.selectable) { if (states.selectable.call(null, row, index) && toggleRowStatus(selection, row, value)) { selectionChanged = true; } } else { if (toggleRowStatus(selection, row, value)) { selectionChanged = true; } } }); if (selectionChanged) { this.table.$emit('selection-change', selection ? selection.slice() : []); } this.table.$emit('select-all', selection); }, updateSelectionByRowKey: function updateSelectionByRowKey() { var states = this.states; var selection = states.selection, rowKey = states.rowKey, data = states.data; var selectedMap = getKeysMap(selection, rowKey); data.forEach(function (row) { var rowId = getRowIdentity(row, rowKey); var rowInfo = selectedMap[rowId]; if (rowInfo) { selection[rowInfo.index] = row; } }); }, updateAllSelected: function updateAllSelected() { var states = this.states; var selection = states.selection, rowKey = states.rowKey, selectable = states.selectable; // data 为 null 时,解构时的默认值会被忽略 var data = states.data || []; if (data.length === 0) { states.isAllSelected = false; return; } var selectedMap = void 0; if (rowKey) { selectedMap = getKeysMap(selection, rowKey); } var isSelected = function isSelected(row) { if (selectedMap) { return !!selectedMap[getRowIdentity(row, rowKey)]; } else { return selection.indexOf(row) !== -1; } }; var isAllSelected = true; var selectedCount = 0; for (var i = 0, j = data.length; i < j; i++) { var item = data[i]; var isRowSelectable = selectable && selectable.call(null, item, i); if (!isSelected(item)) { if (!selectable || isRowSelectable) { isAllSelected = false; break; } } else { selectedCount++; } } if (selectedCount === 0) isAllSelected = false; states.isAllSelected = isAllSelected; }, // 过滤与排序 updateFilters: function updateFilters(columns, values) { if (!Array.isArray(columns)) { columns = [columns]; } var states = this.states; var filters = {}; columns.forEach(function (col) { states.filters[col.id] = values; filters[col.columnKey || col.id] = values; }); return filters; }, updateSort: function updateSort(column, prop, order) { if (this.states.sortingColumn && this.states.sortingColumn !== column) { this.states.sortingColumn.order = null; } this.states.sortingColumn = column; this.states.sortProp = prop; this.states.sortOrder = order; }, execFilter: function execFilter() { var _this = this; var states = this.states; var _data = states._data, filters = states.filters; var data = _data; Object.keys(filters).forEach(function (columnId) { var values = states.filters[columnId]; if (!values || values.length === 0) return; var column = getColumnById(_this.states, columnId); if (column && column.filterMethod) { data = data.filter(function (row) { return values.some(function (value) { return column.filterMethod.call(null, value, row, column); }); }); } }); states.filteredData = data; }, execSort: function execSort() { var states = this.states; states.data = watcher_sortData(states.filteredData, states); }, // 根据 filters 与 sort 去过滤 data execQuery: function execQuery(ignore) { if (!(ignore && ignore.filter)) { this.execFilter(); } this.execSort(); }, clearFilter: function clearFilter(columnKeys) { var states = this.states; var _table$$refs = this.table.$refs, tableHeader = _table$$refs.tableHeader, fixedTableHeader = _table$$refs.fixedTableHeader, rightFixedTableHeader = _table$$refs.rightFixedTableHeader; var panels = {}; if (tableHeader) panels = merge_default()(panels, tableHeader.filterPanels); if (fixedTableHeader) panels = merge_default()(panels, fixedTableHeader.filterPanels); if (rightFixedTableHeader) panels = merge_default()(panels, rightFixedTableHeader.filterPanels); var keys = Object.keys(panels); if (!keys.length) return; if (typeof columnKeys === 'string') { columnKeys = [columnKeys]; } if (Array.isArray(columnKeys)) { var columns = columnKeys.map(function (key) { return getColumnByKey(states, key); }); keys.forEach(function (key) { var column = columns.find(function (col) { return col.id === key; }); if (column) { // TODO: 优化这里的代码 panels[key].filteredValue = []; } }); this.commit('filterChange', { column: columns, values: [], silent: true, multi: true }); } else { keys.forEach(function (key) { // TODO: 优化这里的代码 panels[key].filteredValue = []; }); states.filters = {}; this.commit('filterChange', { column: {}, values: [], silent: true }); } }, clearSort: function clearSort() { var states = this.states; if (!states.sortingColumn) return; this.updateSort(null, null, null); this.commit('changeSortCondition', { silent: true }); }, // 适配层,expand-row-keys 在 Expand 与 TreeTable 中都有使用 setExpandRowKeysAdapter: function setExpandRowKeysAdapter(val) { // 这里会触发额外的计算,但为了兼容性,暂时这么做 this.setExpandRowKeys(val); this.updateTreeExpandKeys(val); }, // 展开行与 TreeTable 都要使用 toggleRowExpansionAdapter: function toggleRowExpansionAdapter(row, expanded) { var hasExpandColumn = this.states.columns.some(function (_ref) { var type = _ref.type; return type === 'expand'; }); if (hasExpandColumn) { this.toggleRowExpansion(row, expanded); } else { this.toggleTreeExpansion(row, expanded); } } } })); // CONCATENATED MODULE: ./packages/table/src/store/index.js watcher.prototype.mutations = { setData: function setData(states, data) { var dataInstanceChanged = states._data !== data; states._data = data; this.execQuery(); // 数据变化,更新部分数据。 // 没有使用 computed,而是手动更新部分数据 https://github.com/vuejs/vue/issues/6660#issuecomment-331417140 this.updateCurrentRowData(); this.updateExpandRows(); if (states.reserveSelection) { this.assertRowKey(); this.updateSelectionByRowKey(); } else { if (dataInstanceChanged) { this.clearSelection(); } else { this.cleanSelection(); } } this.updateAllSelected(); this.updateTableScrollY(); }, insertColumn: function insertColumn(states, column, index, parent) { var array = states._columns; if (parent) { array = parent.children; if (!array) array = parent.children = []; } if (typeof index !== 'undefined') { array.splice(index, 0, column); } else { array.push(column); } if (column.type === 'selection') { states.selectable = column.selectable; states.reserveSelection = column.reserveSelection; } if (this.table.$ready) { this.updateColumns(); // hack for dynamics insert column this.scheduleLayout(); } }, removeColumn: function removeColumn(states, column, parent) { var array = states._columns; if (parent) { array = parent.children; if (!array) array = parent.children = []; } if (array) { array.splice(array.indexOf(column), 1); } if (this.table.$ready) { this.updateColumns(); // hack for dynamics remove column this.scheduleLayout(); } }, sort: function sort(states, options) { var prop = options.prop, order = options.order, init = options.init; if (prop) { var column = Object(util_["arrayFind"])(states.columns, function (column) { return column.property === prop; }); if (column) { column.order = order; this.updateSort(column, prop, order); this.commit('changeSortCondition', { init: init }); } } }, changeSortCondition: function changeSortCondition(states, options) { // 修复 pr https://github.com/ElemeFE/element/pull/15012 导致的 bug var column = states.sortingColumn, prop = states.sortProp, order = states.sortOrder; if (order === null) { states.sortingColumn = null; states.sortProp = null; } var ingore = { filter: true }; this.execQuery(ingore); if (!options || !(options.silent || options.init)) { this.table.$emit('sort-change', { column: column, prop: prop, order: order }); } this.updateTableScrollY(); }, filterChange: function filterChange(states, options) { var column = options.column, values = options.values, silent = options.silent; var newFilters = this.updateFilters(column, values); this.execQuery(); if (!silent) { this.table.$emit('filter-change', newFilters); } this.updateTableScrollY(); }, toggleAllSelection: function toggleAllSelection() { this.toggleAllSelection(); }, rowSelectedChanged: function rowSelectedChanged(states, row) { this.toggleRowSelection(row); this.updateAllSelected(); }, setHoverRow: function setHoverRow(states, row) { states.hoverRow = row; }, setCurrentRow: function setCurrentRow(states, row) { this.updateCurrentRow(row); } }; watcher.prototype.commit = function (name) { var mutations = this.mutations; if (mutations[name]) { for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { args[_key - 1] = arguments[_key]; } mutations[name].apply(this, [this.states].concat(args)); } else { throw new Error('Action not found: ' + name); } }; watcher.prototype.updateTableScrollY = function () { external_vue_default.a.nextTick(this.table.updateScrollY); }; /* harmony default export */ var src_store = (watcher); // CONCATENATED MODULE: ./packages/table/src/store/helper.js function createStore(table) { var initialState = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; if (!table) { throw new Error('Table is required.'); } var store = new src_store(); store.table = table; // fix https://github.com/ElemeFE/element/issues/14075 // related pr https://github.com/ElemeFE/element/pull/14146 store.toggleAllSelection = debounce_default()(10, store._toggleAllSelection); Object.keys(initialState).forEach(function (key) { store.states[key] = initialState[key]; }); return store; } function mapStates(mapper) { var res = {}; Object.keys(mapper).forEach(function (key) { var value = mapper[key]; var fn = void 0; if (typeof value === 'string') { fn = function fn() { return this.store.states[value]; }; } else if (typeof value === 'function') { fn = function fn() { return value.call(this, this.store.states); }; } else { console.error('invalid value type'); } if (fn) { res[key] = fn; } }); return res; }; // EXTERNAL MODULE: external "element-ui/lib/utils/scrollbar-width" var scrollbar_width_ = __webpack_require__(31); var scrollbar_width_default = /*#__PURE__*/__webpack_require__.n(scrollbar_width_); // CONCATENATED MODULE: ./packages/table/src/table-layout.js function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var table_layout_TableLayout = function () { function TableLayout(options) { _classCallCheck(this, TableLayout); this.observers = []; this.table = null; this.store = null; this.columns = null; this.fit = true; this.showHeader = true; this.height = null; this.scrollX = false; this.scrollY = false; this.bodyWidth = null; this.fixedWidth = null; this.rightFixedWidth = null; this.tableHeight = null; this.headerHeight = 44; // Table Header Height this.appendHeight = 0; // Append Slot Height this.footerHeight = 44; // Table Footer Height this.viewportHeight = null; // Table Height - Scroll Bar Height this.bodyHeight = null; // Table Height - Table Header Height this.fixedBodyHeight = null; // Table Height - Table Header Height - Scroll Bar Height this.gutterWidth = scrollbar_width_default()(); for (var name in options) { if (options.hasOwnProperty(name)) { this[name] = options[name]; } } if (!this.table) { throw new Error('table is required for Table Layout'); } if (!this.store) { throw new Error('store is required for Table Layout'); } } TableLayout.prototype.updateScrollY = function updateScrollY() { var height = this.height; if (height === null) return false; var bodyWrapper = this.table.bodyWrapper; if (this.table.$el && bodyWrapper) { var body = bodyWrapper.querySelector('.el-table__body'); var prevScrollY = this.scrollY; var scrollY = body.offsetHeight > this.bodyHeight; this.scrollY = scrollY; return prevScrollY !== scrollY; } return false; }; TableLayout.prototype.setHeight = function setHeight(value) { var _this = this; var prop = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'height'; if (external_vue_default.a.prototype.$isServer) return; var el = this.table.$el; value = parseHeight(value); this.height = value; if (!el && (value || value === 0)) return external_vue_default.a.nextTick(function () { return _this.setHeight(value, prop); }); if (typeof value === 'number') { el.style[prop] = value + 'px'; this.updateElsHeight(); } else if (typeof value === 'string') { el.style[prop] = value; this.updateElsHeight(); } }; TableLayout.prototype.setMaxHeight = function setMaxHeight(value) { this.setHeight(value, 'max-height'); }; TableLayout.prototype.getFlattenColumns = function getFlattenColumns() { var flattenColumns = []; var columns = this.table.columns; columns.forEach(function (column) { if (column.isColumnGroup) { flattenColumns.push.apply(flattenColumns, column.columns); } else { flattenColumns.push(column); } }); return flattenColumns; }; TableLayout.prototype.updateElsHeight = function updateElsHeight() { var _this2 = this; if (!this.table.$ready) return external_vue_default.a.nextTick(function () { return _this2.updateElsHeight(); }); var _table$$refs = this.table.$refs, headerWrapper = _table$$refs.headerWrapper, appendWrapper = _table$$refs.appendWrapper, footerWrapper = _table$$refs.footerWrapper; this.appendHeight = appendWrapper ? appendWrapper.offsetHeight : 0; if (this.showHeader && !headerWrapper) return; // fix issue (https://github.com/ElemeFE/element/pull/16956) var headerTrElm = headerWrapper ? headerWrapper.querySelector('.el-table__header tr') : null; var noneHeader = this.headerDisplayNone(headerTrElm); var headerHeight = this.headerHeight = !this.showHeader ? 0 : headerWrapper.offsetHeight; if (this.showHeader && !noneHeader && headerWrapper.offsetWidth > 0 && (this.table.columns || []).length > 0 && headerHeight < 2) { return external_vue_default.a.nextTick(function () { return _this2.updateElsHeight(); }); } var tableHeight = this.tableHeight = this.table.$el.clientHeight; var footerHeight = this.footerHeight = footerWrapper ? footerWrapper.offsetHeight : 0; if (this.height !== null) { this.bodyHeight = tableHeight - headerHeight - footerHeight + (footerWrapper ? 1 : 0); } this.fixedBodyHeight = this.scrollX ? this.bodyHeight - this.gutterWidth : this.bodyHeight; var noData = !(this.store.states.data && this.store.states.data.length); this.viewportHeight = this.scrollX ? tableHeight - (noData ? 0 : this.gutterWidth) : tableHeight; this.updateScrollY(); this.notifyObservers('scrollable'); }; TableLayout.prototype.headerDisplayNone = function headerDisplayNone(elm) { if (!elm) return true; var headerChild = elm; while (headerChild.tagName !== 'DIV') { if (getComputedStyle(headerChild).display === 'none') { return true; } headerChild = headerChild.parentElement; } return false; }; TableLayout.prototype.updateColumnsWidth = function updateColumnsWidth() { if (external_vue_default.a.prototype.$isServer) return; var fit = this.fit; var bodyWidth = this.table.$el.clientWidth; var bodyMinWidth = 0; var flattenColumns = this.getFlattenColumns(); var flexColumns = flattenColumns.filter(function (column) { return typeof column.width !== 'number'; }); flattenColumns.forEach(function (column) { // Clean those columns whose width changed from flex to unflex if (typeof column.width === 'number' && column.realWidth) column.realWidth = null; }); if (flexColumns.length > 0 && fit) { flattenColumns.forEach(function (column) { bodyMinWidth += column.width || column.minWidth || 80; }); var scrollYWidth = this.scrollY ? this.gutterWidth : 0; if (bodyMinWidth <= bodyWidth - scrollYWidth) { // DON'T HAVE SCROLL BAR this.scrollX = false; var totalFlexWidth = bodyWidth - scrollYWidth - bodyMinWidth; if (flexColumns.length === 1) { flexColumns[0].realWidth = (flexColumns[0].minWidth || 80) + totalFlexWidth; } else { var allColumnsWidth = flexColumns.reduce(function (prev, column) { return prev + (column.minWidth || 80); }, 0); var flexWidthPerPixel = totalFlexWidth / allColumnsWidth; var noneFirstWidth = 0; flexColumns.forEach(function (column, index) { if (index === 0) return; var flexWidth = Math.floor((column.minWidth || 80) * flexWidthPerPixel); noneFirstWidth += flexWidth; column.realWidth = (column.minWidth || 80) + flexWidth; }); flexColumns[0].realWidth = (flexColumns[0].minWidth || 80) + totalFlexWidth - noneFirstWidth; } } else { // HAVE HORIZONTAL SCROLL BAR this.scrollX = true; flexColumns.forEach(function (column) { column.realWidth = column.minWidth; }); } this.bodyWidth = Math.max(bodyMinWidth, bodyWidth); this.table.resizeState.width = this.bodyWidth; } else { flattenColumns.forEach(function (column) { if (!column.width && !column.minWidth) { column.realWidth = 80; } else { column.realWidth = column.width || column.minWidth; } bodyMinWidth += column.realWidth; }); this.scrollX = bodyMinWidth > bodyWidth; this.bodyWidth = bodyMinWidth; } var fixedColumns = this.store.states.fixedColumns; if (fixedColumns.length > 0) { var fixedWidth = 0; fixedColumns.forEach(function (column) { fixedWidth += column.realWidth || column.width; }); this.fixedWidth = fixedWidth; } var rightFixedColumns = this.store.states.rightFixedColumns; if (rightFixedColumns.length > 0) { var rightFixedWidth = 0; rightFixedColumns.forEach(function (column) { rightFixedWidth += column.realWidth || column.width; }); this.rightFixedWidth = rightFixedWidth; } this.notifyObservers('columns'); }; TableLayout.prototype.addObserver = function addObserver(observer) { this.observers.push(observer); }; TableLayout.prototype.removeObserver = function removeObserver(observer) { var index = this.observers.indexOf(observer); if (index !== -1) { this.observers.splice(index, 1); } }; TableLayout.prototype.notifyObservers = function notifyObservers(event) { var _this3 = this; var observers = this.observers; observers.forEach(function (observer) { switch (event) { case 'columns': observer.onColumnsChange(_this3); break; case 'scrollable': observer.onScrollableChange(_this3); break; default: throw new Error('Table Layout don\'t have event ' + event + '.'); } }); }; return TableLayout; }(); /* harmony default export */ var table_layout = (table_layout_TableLayout); // CONCATENATED MODULE: ./packages/table/src/layout-observer.js /* harmony default export */ var layout_observer = ({ created: function created() { this.tableLayout.addObserver(this); }, destroyed: function destroyed() { this.tableLayout.removeObserver(this); }, computed: { tableLayout: function tableLayout() { var layout = this.layout; if (!layout && this.table) { layout = this.table.layout; } if (!layout) { throw new Error('Can not find table layout.'); } return layout; } }, mounted: function mounted() { this.onColumnsChange(this.tableLayout); this.onScrollableChange(this.tableLayout); }, updated: function updated() { if (this.__updated__) return; this.onColumnsChange(this.tableLayout); this.onScrollableChange(this.tableLayout); this.__updated__ = true; }, methods: { onColumnsChange: function onColumnsChange(layout) { var cols = this.$el.querySelectorAll('colgroup > col'); if (!cols.length) return; var flattenColumns = layout.getFlattenColumns(); var columnsMap = {}; flattenColumns.forEach(function (column) { columnsMap[column.id] = column; }); for (var i = 0, j = cols.length; i < j; i++) { var col = cols[i]; var name = col.getAttribute('name'); var column = columnsMap[name]; if (column) { col.setAttribute('width', column.realWidth || column.width); } } }, onScrollableChange: function onScrollableChange(layout) { var cols = this.$el.querySelectorAll('colgroup > col[name=gutter]'); for (var i = 0, j = cols.length; i < j; i++) { var col = cols[i]; col.setAttribute('width', layout.scrollY ? layout.gutterWidth : '0'); } var ths = this.$el.querySelectorAll('th.gutter'); for (var _i = 0, _j = ths.length; _i < _j; _i++) { var th = ths[_i]; th.style.width = layout.scrollY ? layout.gutterWidth + 'px' : '0'; th.style.display = layout.scrollY ? '' : 'none'; } } } }); // CONCATENATED MODULE: ./packages/table/src/table-body.js var table_body_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; }; var table_body_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; /* harmony default export */ var table_body = ({ name: 'ElTableBody', mixins: [layout_observer], components: { ElCheckbox: checkbox_default.a, ElTooltip: tooltip_default.a }, props: { store: { required: true }, stripe: Boolean, context: {}, rowClassName: [String, Function], rowStyle: [Object, Function], fixed: String, highlight: Boolean }, render: function render(h) { var _this = this; var data = this.data || []; return h( 'table', { 'class': 'el-table__body', attrs: { cellspacing: '0', cellpadding: '0', border: '0' } }, [h('colgroup', [this.columns.map(function (column) { return h('col', { attrs: { name: column.id }, key: column.id }); })]), h('tbody', [data.reduce(function (acc, row) { return acc.concat(_this.wrappedRowRender(row, acc.length)); }, []), h('el-tooltip', { attrs: { effect: this.table.tooltipEffect, placement: 'top', content: this.tooltipContent }, ref: 'tooltip' })])] ); }, computed: table_body_extends({ table: function table() { return this.$parent; } }, mapStates({ data: 'data', columns: 'columns', treeIndent: 'indent', leftFixedLeafCount: 'fixedLeafColumnsLength', rightFixedLeafCount: 'rightFixedLeafColumnsLength', columnsCount: function columnsCount(states) { return states.columns.length; }, leftFixedCount: function leftFixedCount(states) { return states.fixedColumns.length; }, rightFixedCount: function rightFixedCount(states) { return states.rightFixedColumns.length; }, hasExpandColumn: function hasExpandColumn(states) { return states.columns.some(function (_ref) { var type = _ref.type; return type === 'expand'; }); } }), { firstDefaultColumnIndex: function firstDefaultColumnIndex() { return Object(util_["arrayFindIndex"])(this.columns, function (_ref2) { var type = _ref2.type; return type === 'default'; }); } }), watch: { // don't trigger getter of currentRow in getCellClass. see https://jsfiddle.net/oe2b4hqt/ // update DOM manually. see https://github.com/ElemeFE/element/pull/13954/files#diff-9b450c00d0a9dec0ffad5a3176972e40 'store.states.hoverRow': function storeStatesHoverRow(newVal, oldVal) { var _this2 = this; if (!this.store.states.isComplex || this.$isServer) return; var raf = window.requestAnimationFrame; if (!raf) { raf = function raf(fn) { return setTimeout(fn, 16); }; } raf(function () { var rows = _this2.$el.querySelectorAll('.el-table__row'); var oldRow = rows[oldVal]; var newRow = rows[newVal]; if (oldRow) { Object(dom_["removeClass"])(oldRow, 'hover-row'); } if (newRow) { Object(dom_["addClass"])(newRow, 'hover-row'); } }); } }, data: function data() { return { tooltipContent: '' }; }, created: function created() { this.activateTooltip = debounce_default()(50, function (tooltip) { return tooltip.handleShowPopper(); }); }, methods: { getKeyOfRow: function getKeyOfRow(row, index) { var rowKey = this.table.rowKey; if (rowKey) { return getRowIdentity(row, rowKey); } return index; }, isColumnHidden: function isColumnHidden(index) { if (this.fixed === true || this.fixed === 'left') { return index >= this.leftFixedLeafCount; } else if (this.fixed === 'right') { return index < this.columnsCount - this.rightFixedLeafCount; } else { return index < this.leftFixedLeafCount || index >= this.columnsCount - this.rightFixedLeafCount; } }, getSpan: function getSpan(row, column, rowIndex, columnIndex) { var rowspan = 1; var colspan = 1; var fn = this.table.spanMethod; if (typeof fn === 'function') { var result = fn({ row: row, column: column, rowIndex: rowIndex, columnIndex: columnIndex }); if (Array.isArray(result)) { rowspan = result[0]; colspan = result[1]; } else if ((typeof result === 'undefined' ? 'undefined' : table_body_typeof(result)) === 'object') { rowspan = result.rowspan; colspan = result.colspan; } } return { rowspan: rowspan, colspan: colspan }; }, getRowStyle: function getRowStyle(row, rowIndex) { var rowStyle = this.table.rowStyle; if (typeof rowStyle === 'function') { return rowStyle.call(null, { row: row, rowIndex: rowIndex }); } return rowStyle || null; }, getRowClass: function getRowClass(row, rowIndex) { var classes = ['el-table__row']; if (this.table.highlightCurrentRow && row === this.store.states.currentRow) { classes.push('current-row'); } if (this.stripe && rowIndex % 2 === 1) { classes.push('el-table__row--striped'); } var rowClassName = this.table.rowClassName; if (typeof rowClassName === 'string') { classes.push(rowClassName); } else if (typeof rowClassName === 'function') { classes.push(rowClassName.call(null, { row: row, rowIndex: rowIndex })); } if (this.store.states.expandRows.indexOf(row) > -1) { classes.push('expanded'); } return classes; }, getCellStyle: function getCellStyle(rowIndex, columnIndex, row, column) { var cellStyle = this.table.cellStyle; if (typeof cellStyle === 'function') { return cellStyle.call(null, { rowIndex: rowIndex, columnIndex: columnIndex, row: row, column: column }); } return cellStyle; }, getCellClass: function getCellClass(rowIndex, columnIndex, row, column) { var classes = [column.id, column.align, column.className]; if (this.isColumnHidden(columnIndex)) { classes.push('is-hidden'); } var cellClassName = this.table.cellClassName; if (typeof cellClassName === 'string') { classes.push(cellClassName); } else if (typeof cellClassName === 'function') { classes.push(cellClassName.call(null, { rowIndex: rowIndex, columnIndex: columnIndex, row: row, column: column })); } return classes.join(' '); }, getColspanRealWidth: function getColspanRealWidth(columns, colspan, index) { if (colspan < 1) { return columns[index].realWidth; } var widthArr = columns.map(function (_ref3) { var realWidth = _ref3.realWidth; return realWidth; }).slice(index, index + colspan); return widthArr.reduce(function (acc, width) { return acc + width; }, -1); }, handleCellMouseEnter: function handleCellMouseEnter(event, row) { var table = this.table; var cell = getCell(event); if (cell) { var column = getColumnByCell(table, cell); var hoverState = table.hoverState = { cell: cell, column: column, row: row }; table.$emit('cell-mouse-enter', hoverState.row, hoverState.column, hoverState.cell, event); } // 判断是否text-overflow, 如果是就显示tooltip var cellChild = event.target.querySelector('.cell'); if (!(Object(dom_["hasClass"])(cellChild, 'el-tooltip') && cellChild.childNodes.length)) { return; } // use range width instead of scrollWidth to determine whether the text is overflowing // to address a potential FireFox bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1074543#c3 var range = document.createRange(); range.setStart(cellChild, 0); range.setEnd(cellChild, cellChild.childNodes.length); var rangeWidth = range.getBoundingClientRect().width; var padding = (parseInt(Object(dom_["getStyle"])(cellChild, 'paddingLeft'), 10) || 0) + (parseInt(Object(dom_["getStyle"])(cellChild, 'paddingRight'), 10) || 0); if ((rangeWidth + padding > cellChild.offsetWidth || cellChild.scrollWidth > cellChild.offsetWidth) && this.$refs.tooltip) { var tooltip = this.$refs.tooltip; // TODO 会引起整个 Table 的重新渲染,需要优化 this.tooltipContent = cell.innerText || cell.textContent; tooltip.referenceElm = cell; tooltip.$refs.popper && (tooltip.$refs.popper.style.display = 'none'); tooltip.doDestroy(); tooltip.setExpectedState(true); this.activateTooltip(tooltip); } }, handleCellMouseLeave: function handleCellMouseLeave(event) { var tooltip = this.$refs.tooltip; if (tooltip) { tooltip.setExpectedState(false); tooltip.handleClosePopper(); } var cell = getCell(event); if (!cell) return; var oldHoverState = this.table.hoverState || {}; this.table.$emit('cell-mouse-leave', oldHoverState.row, oldHoverState.column, oldHoverState.cell, event); }, handleMouseEnter: debounce_default()(30, function (index) { this.store.commit('setHoverRow', index); }), handleMouseLeave: debounce_default()(30, function () { this.store.commit('setHoverRow', null); }), handleContextMenu: function handleContextMenu(event, row) { this.handleEvent(event, row, 'contextmenu'); }, handleDoubleClick: function handleDoubleClick(event, row) { this.handleEvent(event, row, 'dblclick'); }, handleClick: function handleClick(event, row) { this.store.commit('setCurrentRow', row); this.handleEvent(event, row, 'click'); }, handleEvent: function handleEvent(event, row, name) { var table = this.table; var cell = getCell(event); var column = void 0; if (cell) { column = getColumnByCell(table, cell); if (column) { table.$emit('cell-' + name, row, column, cell, event); } } table.$emit('row-' + name, row, column, event); }, rowRender: function rowRender(row, $index, treeRowData) { var _this3 = this; var h = this.$createElement; var treeIndent = this.treeIndent, columns = this.columns, firstDefaultColumnIndex = this.firstDefaultColumnIndex; var columnsHidden = columns.map(function (column, index) { return _this3.isColumnHidden(index); }); var rowClasses = this.getRowClass(row, $index); var display = true; if (treeRowData) { rowClasses.push('el-table__row--level-' + treeRowData.level); display = treeRowData.display; } // 指令 v-show 会覆盖 row-style 中 display // 使用 :style 代替 v-show https://github.com/ElemeFE/element/issues/16995 var displayStyle = display ? null : { display: 'none' }; return h( 'tr', { style: [displayStyle, this.getRowStyle(row, $index)], 'class': rowClasses, key: this.getKeyOfRow(row, $index), on: { 'dblclick': function dblclick($event) { return _this3.handleDoubleClick($event, row); }, 'click': function click($event) { return _this3.handleClick($event, row); }, 'contextmenu': function contextmenu($event) { return _this3.handleContextMenu($event, row); }, 'mouseenter': function mouseenter(_) { return _this3.handleMouseEnter($index); }, 'mouseleave': this.handleMouseLeave } }, [columns.map(function (column, cellIndex) { var _getSpan = _this3.getSpan(row, column, $index, cellIndex), rowspan = _getSpan.rowspan, colspan = _getSpan.colspan; if (!rowspan || !colspan) { return null; } var columnData = table_body_extends({}, column); columnData.realWidth = _this3.getColspanRealWidth(columns, colspan, cellIndex); var data = { store: _this3.store, _self: _this3.context || _this3.table.$vnode.context, column: columnData, row: row, $index: $index }; if (cellIndex === firstDefaultColumnIndex && treeRowData) { data.treeNode = { indent: treeRowData.level * treeIndent, level: treeRowData.level }; if (typeof treeRowData.expanded === 'boolean') { data.treeNode.expanded = treeRowData.expanded; // 表明是懒加载 if ('loading' in treeRowData) { data.treeNode.loading = treeRowData.loading; } if ('noLazyChildren' in treeRowData) { data.treeNode.noLazyChildren = treeRowData.noLazyChildren; } } } return h( 'td', { style: _this3.getCellStyle($index, cellIndex, row, column), 'class': _this3.getCellClass($index, cellIndex, row, column), attrs: { rowspan: rowspan, colspan: colspan }, on: { 'mouseenter': function mouseenter($event) { return _this3.handleCellMouseEnter($event, row); }, 'mouseleave': _this3.handleCellMouseLeave } }, [column.renderCell.call(_this3._renderProxy, _this3.$createElement, data, columnsHidden[cellIndex])] ); })] ); }, wrappedRowRender: function wrappedRowRender(row, $index) { var _this4 = this; var h = this.$createElement; var store = this.store; var isRowExpanded = store.isRowExpanded, assertRowKey = store.assertRowKey; var _store$states = store.states, treeData = _store$states.treeData, lazyTreeNodeMap = _store$states.lazyTreeNodeMap, childrenColumnName = _store$states.childrenColumnName, rowKey = _store$states.rowKey; if (this.hasExpandColumn && isRowExpanded(row)) { var renderExpanded = this.table.renderExpanded; var tr = this.rowRender(row, $index); if (!renderExpanded) { console.error('[Element Error]renderExpanded is required.'); return tr; } // 使用二维数组,避免修改 $index return [[tr, h( 'tr', { key: 'expanded-row__' + tr.key }, [h( 'td', { attrs: { colspan: this.columnsCount }, 'class': 'el-table__expanded-cell' }, [renderExpanded(this.$createElement, { row: row, $index: $index, store: this.store })] )] )]]; } else if (Object.keys(treeData).length) { assertRowKey(); // TreeTable 时,rowKey 必须由用户设定,不使用 getKeyOfRow 计算 // 在调用 rowRender 函数时,仍然会计算 rowKey,不太好的操作 var key = getRowIdentity(row, rowKey); var cur = treeData[key]; var treeRowData = null; if (cur) { treeRowData = { expanded: cur.expanded, level: cur.level, display: true }; if (typeof cur.lazy === 'boolean') { if (typeof cur.loaded === 'boolean' && cur.loaded) { treeRowData.noLazyChildren = !(cur.children && cur.children.length); } treeRowData.loading = cur.loading; } } var tmp = [this.rowRender(row, $index, treeRowData)]; // 渲染嵌套数据 if (cur) { // currentRow 记录的是 index,所以还需主动增加 TreeTable 的 index var i = 0; var traverse = function traverse(children, parent) { if (!(children && children.length && parent)) return; children.forEach(function (node) { // 父节点的 display 状态影响子节点的显示状态 var innerTreeRowData = { display: parent.display && parent.expanded, level: parent.level + 1 }; var childKey = getRowIdentity(node, rowKey); if (childKey === undefined || childKey === null) { throw new Error('for nested data item, row-key is required.'); } cur = table_body_extends({}, treeData[childKey]); // 对于当前节点,分成有无子节点两种情况。 // 如果包含子节点的,设置 expanded 属性。 // 对于它子节点的 display 属性由它本身的 expanded 与 display 共同决定。 if (cur) { innerTreeRowData.expanded = cur.expanded; // 懒加载的某些节点,level 未知 cur.level = cur.level || innerTreeRowData.level; cur.display = !!(cur.expanded && innerTreeRowData.display); if (typeof cur.lazy === 'boolean') { if (typeof cur.loaded === 'boolean' && cur.loaded) { innerTreeRowData.noLazyChildren = !(cur.children && cur.children.length); } innerTreeRowData.loading = cur.loading; } } i++; tmp.push(_this4.rowRender(node, $index + i, innerTreeRowData)); if (cur) { var _nodes = lazyTreeNodeMap[childKey] || node[childrenColumnName]; traverse(_nodes, cur); } }); }; // 对于 root 节点,display 一定为 true cur.display = true; var nodes = lazyTreeNodeMap[key] || row[childrenColumnName]; traverse(nodes, cur); } return tmp; } else { return this.rowRender(row, $index); } } } }); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/table/src/filter-panel.vue?vue&type=template&id=7f2c919f& var filter_panelvue_type_template_id_7f2c919f_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("transition", { attrs: { name: "el-zoom-in-top" } }, [ _vm.multiple ? _c( "div", { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: _vm.handleOutsideClick, expression: "handleOutsideClick" }, { name: "show", rawName: "v-show", value: _vm.showPopper, expression: "showPopper" } ], staticClass: "el-table-filter" }, [ _c( "div", { staticClass: "el-table-filter__content" }, [ _c( "el-scrollbar", { attrs: { "wrap-class": "el-table-filter__wrap" } }, [ _c( "el-checkbox-group", { staticClass: "el-table-filter__checkbox-group", model: { value: _vm.filteredValue, callback: function($$v) { _vm.filteredValue = $$v }, expression: "filteredValue" } }, _vm._l(_vm.filters, function(filter) { return _c( "el-checkbox", { key: filter.value, attrs: { label: filter.value } }, [_vm._v(_vm._s(filter.text))] ) }), 1 ) ], 1 ) ], 1 ), _c("div", { staticClass: "el-table-filter__bottom" }, [ _c( "button", { class: { "is-disabled": _vm.filteredValue.length === 0 }, attrs: { disabled: _vm.filteredValue.length === 0 }, on: { click: _vm.handleConfirm } }, [_vm._v(_vm._s(_vm.t("el.table.confirmFilter")))] ), _c("button", { on: { click: _vm.handleReset } }, [ _vm._v(_vm._s(_vm.t("el.table.resetFilter"))) ]) ]) ] ) : _c( "div", { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: _vm.handleOutsideClick, expression: "handleOutsideClick" }, { name: "show", rawName: "v-show", value: _vm.showPopper, expression: "showPopper" } ], staticClass: "el-table-filter" }, [ _c( "ul", { staticClass: "el-table-filter__list" }, [ _c( "li", { staticClass: "el-table-filter__list-item", class: { "is-active": _vm.filterValue === undefined || _vm.filterValue === null }, on: { click: function($event) { _vm.handleSelect(null) } } }, [_vm._v(_vm._s(_vm.t("el.table.clearFilter")))] ), _vm._l(_vm.filters, function(filter) { return _c( "li", { key: filter.value, staticClass: "el-table-filter__list-item", class: { "is-active": _vm.isActive(filter) }, attrs: { label: filter.value }, on: { click: function($event) { _vm.handleSelect(filter.value) } } }, [_vm._v(_vm._s(filter.text))] ) }) ], 2 ) ] ) ]) } var filter_panelvue_type_template_id_7f2c919f_staticRenderFns = [] filter_panelvue_type_template_id_7f2c919f_render._withStripped = true // CONCATENATED MODULE: ./packages/table/src/filter-panel.vue?vue&type=template&id=7f2c919f& // CONCATENATED MODULE: ./packages/table/src/dropdown.js var dropdowns = []; !external_vue_default.a.prototype.$isServer && document.addEventListener('click', function (event) { dropdowns.forEach(function (dropdown) { var target = event.target; if (!dropdown || !dropdown.$el) return; if (target === dropdown.$el || dropdown.$el.contains(target)) { return; } dropdown.handleOutsideClick && dropdown.handleOutsideClick(event); }); }); /* harmony default export */ var src_dropdown = ({ open: function open(instance) { if (instance) { dropdowns.push(instance); } }, close: function close(instance) { var index = dropdowns.indexOf(instance); if (index !== -1) { dropdowns.splice(instance, 1); } } }); // EXTERNAL MODULE: external "element-ui/lib/checkbox-group" var checkbox_group_ = __webpack_require__(32); var checkbox_group_default = /*#__PURE__*/__webpack_require__.n(checkbox_group_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/table/src/filter-panel.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var filter_panelvue_type_script_lang_js_ = ({ name: 'ElTableFilterPanel', mixins: [vue_popper_default.a, locale_default.a], directives: { Clickoutside: clickoutside_default.a }, components: { ElCheckbox: checkbox_default.a, ElCheckboxGroup: checkbox_group_default.a, ElScrollbar: scrollbar_default.a }, props: { placement: { type: String, default: 'bottom-end' } }, methods: { isActive: function isActive(filter) { return filter.value === this.filterValue; }, handleOutsideClick: function handleOutsideClick() { var _this = this; setTimeout(function () { _this.showPopper = false; }, 16); }, handleConfirm: function handleConfirm() { this.confirmFilter(this.filteredValue); this.handleOutsideClick(); }, handleReset: function handleReset() { this.filteredValue = []; this.confirmFilter(this.filteredValue); this.handleOutsideClick(); }, handleSelect: function handleSelect(filterValue) { this.filterValue = filterValue; if (typeof filterValue !== 'undefined' && filterValue !== null) { this.confirmFilter(this.filteredValue); } else { this.confirmFilter([]); } this.handleOutsideClick(); }, confirmFilter: function confirmFilter(filteredValue) { this.table.store.commit('filterChange', { column: this.column, values: filteredValue }); this.table.store.updateAllSelected(); } }, data: function data() { return { table: null, cell: null, column: null }; }, computed: { filters: function filters() { return this.column && this.column.filters; }, filterValue: { get: function get() { return (this.column.filteredValue || [])[0]; }, set: function set(value) { if (this.filteredValue) { if (typeof value !== 'undefined' && value !== null) { this.filteredValue.splice(0, 1, value); } else { this.filteredValue.splice(0, 1); } } } }, filteredValue: { get: function get() { if (this.column) { return this.column.filteredValue || []; } return []; }, set: function set(value) { if (this.column) { this.column.filteredValue = value; } } }, multiple: function multiple() { if (this.column) { return this.column.filterMultiple; } return true; } }, mounted: function mounted() { var _this2 = this; this.popperElm = this.$el; this.referenceElm = this.cell; this.table.bodyWrapper.addEventListener('scroll', function () { _this2.updatePopper(); }); this.$watch('showPopper', function (value) { if (_this2.column) _this2.column.filterOpened = value; if (value) { src_dropdown.open(_this2); } else { src_dropdown.close(_this2); } }); }, watch: { showPopper: function showPopper(val) { if (val === true && parseInt(this.popperJS._popper.style.zIndex, 10) < popup_["PopupManager"].zIndex) { this.popperJS._popper.style.zIndex = popup_["PopupManager"].nextZIndex(); } } } }); // CONCATENATED MODULE: ./packages/table/src/filter-panel.vue?vue&type=script&lang=js& /* harmony default export */ var src_filter_panelvue_type_script_lang_js_ = (filter_panelvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/table/src/filter-panel.vue /* normalize component */ var filter_panel_component = normalizeComponent( src_filter_panelvue_type_script_lang_js_, filter_panelvue_type_template_id_7f2c919f_render, filter_panelvue_type_template_id_7f2c919f_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var filter_panel_api; } filter_panel_component.options.__file = "packages/table/src/filter-panel.vue" /* harmony default export */ var filter_panel = (filter_panel_component.exports); // CONCATENATED MODULE: ./packages/table/src/table-header.js var table_header_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var getAllColumns = function getAllColumns(columns) { var result = []; columns.forEach(function (column) { if (column.children) { result.push(column); result.push.apply(result, getAllColumns(column.children)); } else { result.push(column); } }); return result; }; var convertToRows = function convertToRows(originColumns) { var maxLevel = 1; var traverse = function traverse(column, parent) { if (parent) { column.level = parent.level + 1; if (maxLevel < column.level) { maxLevel = column.level; } } if (column.children) { var colSpan = 0; column.children.forEach(function (subColumn) { traverse(subColumn, column); colSpan += subColumn.colSpan; }); column.colSpan = colSpan; } else { column.colSpan = 1; } }; originColumns.forEach(function (column) { column.level = 1; traverse(column); }); var rows = []; for (var i = 0; i < maxLevel; i++) { rows.push([]); } var allColumns = getAllColumns(originColumns); allColumns.forEach(function (column) { if (!column.children) { column.rowSpan = maxLevel - column.level + 1; } else { column.rowSpan = 1; } rows[column.level - 1].push(column); }); return rows; }; /* harmony default export */ var table_header = ({ name: 'ElTableHeader', mixins: [layout_observer], render: function render(h) { var _this = this; var originColumns = this.store.states.originColumns; var columnRows = convertToRows(originColumns, this.columns); // 是否拥有多级表头 var isGroup = columnRows.length > 1; if (isGroup) this.$parent.isGroup = true; return h( 'table', { 'class': 'el-table__header', attrs: { cellspacing: '0', cellpadding: '0', border: '0' } }, [h('colgroup', [this.columns.map(function (column) { return h('col', { attrs: { name: column.id }, key: column.id }); }), this.hasGutter ? h('col', { attrs: { name: 'gutter' } }) : '']), h( 'thead', { 'class': [{ 'is-group': isGroup, 'has-gutter': this.hasGutter }] }, [this._l(columnRows, function (columns, rowIndex) { return h( 'tr', { style: _this.getHeaderRowStyle(rowIndex), 'class': _this.getHeaderRowClass(rowIndex) }, [columns.map(function (column, cellIndex) { return h( 'th', { attrs: { colspan: column.colSpan, rowspan: column.rowSpan }, on: { 'mousemove': function mousemove($event) { return _this.handleMouseMove($event, column); }, 'mouseout': _this.handleMouseOut, 'mousedown': function mousedown($event) { return _this.handleMouseDown($event, column); }, 'click': function click($event) { return _this.handleHeaderClick($event, column); }, 'contextmenu': function contextmenu($event) { return _this.handleHeaderContextMenu($event, column); } }, style: _this.getHeaderCellStyle(rowIndex, cellIndex, columns, column), 'class': _this.getHeaderCellClass(rowIndex, cellIndex, columns, column), key: column.id }, [h( 'div', { 'class': ['cell', column.filteredValue && column.filteredValue.length > 0 ? 'highlight' : '', column.labelClassName] }, [column.renderHeader ? column.renderHeader.call(_this._renderProxy, h, { column: column, $index: cellIndex, store: _this.store, _self: _this.$parent.$vnode.context }) : column.label, column.sortable ? h( 'span', { 'class': 'caret-wrapper', on: { 'click': function click($event) { return _this.handleSortClick($event, column); } } }, [h('i', { 'class': 'sort-caret ascending', on: { 'click': function click($event) { return _this.handleSortClick($event, column, 'ascending'); } } }), h('i', { 'class': 'sort-caret descending', on: { 'click': function click($event) { return _this.handleSortClick($event, column, 'descending'); } } })] ) : '', column.filterable ? h( 'span', { 'class': 'el-table__column-filter-trigger', on: { 'click': function click($event) { return _this.handleFilterClick($event, column); } } }, [h('i', { 'class': ['el-icon-arrow-down', column.filterOpened ? 'el-icon-arrow-up' : ''] })] ) : ''] )] ); }), _this.hasGutter ? h('th', { 'class': 'gutter' }) : ''] ); })] )] ); }, props: { fixed: String, store: { required: true }, border: Boolean, defaultSort: { type: Object, default: function _default() { return { prop: '', order: '' }; } } }, components: { ElCheckbox: checkbox_default.a }, computed: table_header_extends({ table: function table() { return this.$parent; }, hasGutter: function hasGutter() { return !this.fixed && this.tableLayout.gutterWidth; } }, mapStates({ columns: 'columns', isAllSelected: 'isAllSelected', leftFixedLeafCount: 'fixedLeafColumnsLength', rightFixedLeafCount: 'rightFixedLeafColumnsLength', columnsCount: function columnsCount(states) { return states.columns.length; }, leftFixedCount: function leftFixedCount(states) { return states.fixedColumns.length; }, rightFixedCount: function rightFixedCount(states) { return states.rightFixedColumns.length; } })), created: function created() { this.filterPanels = {}; }, mounted: function mounted() { var _this2 = this; // nextTick 是有必要的 https://github.com/ElemeFE/element/pull/11311 this.$nextTick(function () { var _defaultSort = _this2.defaultSort, prop = _defaultSort.prop, order = _defaultSort.order; var init = true; _this2.store.commit('sort', { prop: prop, order: order, init: init }); }); }, beforeDestroy: function beforeDestroy() { var panels = this.filterPanels; for (var prop in panels) { if (panels.hasOwnProperty(prop) && panels[prop]) { panels[prop].$destroy(true); } } }, methods: { isCellHidden: function isCellHidden(index, columns) { var start = 0; for (var i = 0; i < index; i++) { start += columns[i].colSpan; } var after = start + columns[index].colSpan - 1; if (this.fixed === true || this.fixed === 'left') { return after >= this.leftFixedLeafCount; } else if (this.fixed === 'right') { return start < this.columnsCount - this.rightFixedLeafCount; } else { return after < this.leftFixedLeafCount || start >= this.columnsCount - this.rightFixedLeafCount; } }, getHeaderRowStyle: function getHeaderRowStyle(rowIndex) { var headerRowStyle = this.table.headerRowStyle; if (typeof headerRowStyle === 'function') { return headerRowStyle.call(null, { rowIndex: rowIndex }); } return headerRowStyle; }, getHeaderRowClass: function getHeaderRowClass(rowIndex) { var classes = []; var headerRowClassName = this.table.headerRowClassName; if (typeof headerRowClassName === 'string') { classes.push(headerRowClassName); } else if (typeof headerRowClassName === 'function') { classes.push(headerRowClassName.call(null, { rowIndex: rowIndex })); } return classes.join(' '); }, getHeaderCellStyle: function getHeaderCellStyle(rowIndex, columnIndex, row, column) { var headerCellStyle = this.table.headerCellStyle; if (typeof headerCellStyle === 'function') { return headerCellStyle.call(null, { rowIndex: rowIndex, columnIndex: columnIndex, row: row, column: column }); } return headerCellStyle; }, getHeaderCellClass: function getHeaderCellClass(rowIndex, columnIndex, row, column) { var classes = [column.id, column.order, column.headerAlign, column.className, column.labelClassName]; if (rowIndex === 0 && this.isCellHidden(columnIndex, row)) { classes.push('is-hidden'); } if (!column.children) { classes.push('is-leaf'); } if (column.sortable) { classes.push('is-sortable'); } var headerCellClassName = this.table.headerCellClassName; if (typeof headerCellClassName === 'string') { classes.push(headerCellClassName); } else if (typeof headerCellClassName === 'function') { classes.push(headerCellClassName.call(null, { rowIndex: rowIndex, columnIndex: columnIndex, row: row, column: column })); } return classes.join(' '); }, toggleAllSelection: function toggleAllSelection(event) { event.stopPropagation(); this.store.commit('toggleAllSelection'); }, handleFilterClick: function handleFilterClick(event, column) { event.stopPropagation(); var target = event.target; var cell = target.tagName === 'TH' ? target : target.parentNode; if (Object(dom_["hasClass"])(cell, 'noclick')) return; cell = cell.querySelector('.el-table__column-filter-trigger') || cell; var table = this.$parent; var filterPanel = this.filterPanels[column.id]; if (filterPanel && column.filterOpened) { filterPanel.showPopper = false; return; } if (!filterPanel) { filterPanel = new external_vue_default.a(filter_panel); this.filterPanels[column.id] = filterPanel; if (column.filterPlacement) { filterPanel.placement = column.filterPlacement; } filterPanel.table = table; filterPanel.cell = cell; filterPanel.column = column; !this.$isServer && filterPanel.$mount(document.createElement('div')); } setTimeout(function () { filterPanel.showPopper = true; }, 16); }, handleHeaderClick: function handleHeaderClick(event, column) { if (!column.filters && column.sortable) { this.handleSortClick(event, column); } else if (column.filterable && !column.sortable) { this.handleFilterClick(event, column); } this.$parent.$emit('header-click', column, event); }, handleHeaderContextMenu: function handleHeaderContextMenu(event, column) { this.$parent.$emit('header-contextmenu', column, event); }, handleMouseDown: function handleMouseDown(event, column) { var _this3 = this; if (this.$isServer) return; if (column.children && column.children.length > 0) return; /* istanbul ignore if */ if (this.draggingColumn && this.border) { this.dragging = true; this.$parent.resizeProxyVisible = true; var table = this.$parent; var tableEl = table.$el; var tableLeft = tableEl.getBoundingClientRect().left; var columnEl = this.$el.querySelector('th.' + column.id); var columnRect = columnEl.getBoundingClientRect(); var minLeft = columnRect.left - tableLeft + 30; Object(dom_["addClass"])(columnEl, 'noclick'); this.dragState = { startMouseLeft: event.clientX, startLeft: columnRect.right - tableLeft, startColumnLeft: columnRect.left - tableLeft, tableLeft: tableLeft }; var resizeProxy = table.$refs.resizeProxy; resizeProxy.style.left = this.dragState.startLeft + 'px'; document.onselectstart = function () { return false; }; document.ondragstart = function () { return false; }; var handleMouseMove = function handleMouseMove(event) { var deltaLeft = event.clientX - _this3.dragState.startMouseLeft; var proxyLeft = _this3.dragState.startLeft + deltaLeft; resizeProxy.style.left = Math.max(minLeft, proxyLeft) + 'px'; }; var handleMouseUp = function handleMouseUp() { if (_this3.dragging) { var _dragState = _this3.dragState, startColumnLeft = _dragState.startColumnLeft, startLeft = _dragState.startLeft; var finalLeft = parseInt(resizeProxy.style.left, 10); var columnWidth = finalLeft - startColumnLeft; column.width = column.realWidth = columnWidth; table.$emit('header-dragend', column.width, startLeft - startColumnLeft, column, event); _this3.store.scheduleLayout(); document.body.style.cursor = ''; _this3.dragging = false; _this3.draggingColumn = null; _this3.dragState = {}; table.resizeProxyVisible = false; } document.removeEventListener('mousemove', handleMouseMove); document.removeEventListener('mouseup', handleMouseUp); document.onselectstart = null; document.ondragstart = null; setTimeout(function () { Object(dom_["removeClass"])(columnEl, 'noclick'); }, 0); }; document.addEventListener('mousemove', handleMouseMove); document.addEventListener('mouseup', handleMouseUp); } }, handleMouseMove: function handleMouseMove(event, column) { if (column.children && column.children.length > 0) return; var target = event.target; while (target && target.tagName !== 'TH') { target = target.parentNode; } if (!column || !column.resizable) return; if (!this.dragging && this.border) { var rect = target.getBoundingClientRect(); var bodyStyle = document.body.style; if (rect.width > 12 && rect.right - event.pageX < 8) { bodyStyle.cursor = 'col-resize'; if (Object(dom_["hasClass"])(target, 'is-sortable')) { target.style.cursor = 'col-resize'; } this.draggingColumn = column; } else if (!this.dragging) { bodyStyle.cursor = ''; if (Object(dom_["hasClass"])(target, 'is-sortable')) { target.style.cursor = 'pointer'; } this.draggingColumn = null; } } }, handleMouseOut: function handleMouseOut() { if (this.$isServer) return; document.body.style.cursor = ''; }, toggleOrder: function toggleOrder(_ref) { var order = _ref.order, sortOrders = _ref.sortOrders; if (order === '') return sortOrders[0]; var index = sortOrders.indexOf(order || null); return sortOrders[index > sortOrders.length - 2 ? 0 : index + 1]; }, handleSortClick: function handleSortClick(event, column, givenOrder) { event.stopPropagation(); var order = column.order === givenOrder ? null : givenOrder || this.toggleOrder(column); var target = event.target; while (target && target.tagName !== 'TH') { target = target.parentNode; } if (target && target.tagName === 'TH') { if (Object(dom_["hasClass"])(target, 'noclick')) { Object(dom_["removeClass"])(target, 'noclick'); return; } } if (!column.sortable) return; var states = this.store.states; var sortProp = states.sortProp; var sortOrder = void 0; var sortingColumn = states.sortingColumn; if (sortingColumn !== column || sortingColumn === column && sortingColumn.order === null) { if (sortingColumn) { sortingColumn.order = null; } states.sortingColumn = column; sortProp = column.property; } if (!order) { sortOrder = column.order = null; } else { sortOrder = column.order = order; } states.sortProp = sortProp; states.sortOrder = sortOrder; this.store.commit('changeSortCondition'); } }, data: function data() { return { draggingColumn: null, dragging: false, dragState: {} }; } }); // CONCATENATED MODULE: ./packages/table/src/table-footer.js var table_footer_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; /* harmony default export */ var table_footer = ({ name: 'ElTableFooter', mixins: [layout_observer], render: function render(h) { var _this = this; var sums = []; if (this.summaryMethod) { sums = this.summaryMethod({ columns: this.columns, data: this.store.states.data }); } else { this.columns.forEach(function (column, index) { if (index === 0) { sums[index] = _this.sumText; return; } var values = _this.store.states.data.map(function (item) { return Number(item[column.property]); }); var precisions = []; var notNumber = true; values.forEach(function (value) { if (!isNaN(value)) { notNumber = false; var decimal = ('' + value).split('.')[1]; precisions.push(decimal ? decimal.length : 0); } }); var precision = Math.max.apply(null, precisions); if (!notNumber) { sums[index] = values.reduce(function (prev, curr) { var value = Number(curr); if (!isNaN(value)) { return parseFloat((prev + curr).toFixed(Math.min(precision, 20))); } else { return prev; } }, 0); } else { sums[index] = ''; } }); } return h( 'table', { 'class': 'el-table__footer', attrs: { cellspacing: '0', cellpadding: '0', border: '0' } }, [h('colgroup', [this.columns.map(function (column) { return h('col', { attrs: { name: column.id }, key: column.id }); }), this.hasGutter ? h('col', { attrs: { name: 'gutter' } }) : '']), h( 'tbody', { 'class': [{ 'has-gutter': this.hasGutter }] }, [h('tr', [this.columns.map(function (column, cellIndex) { return h( 'td', { key: cellIndex, attrs: { colspan: column.colSpan, rowspan: column.rowSpan }, 'class': _this.getRowClasses(column, cellIndex) }, [h( 'div', { 'class': ['cell', column.labelClassName] }, [sums[cellIndex]] )] ); }), this.hasGutter ? h('th', { 'class': 'gutter' }) : ''])] )] ); }, props: { fixed: String, store: { required: true }, summaryMethod: Function, sumText: String, border: Boolean, defaultSort: { type: Object, default: function _default() { return { prop: '', order: '' }; } } }, computed: table_footer_extends({ table: function table() { return this.$parent; }, hasGutter: function hasGutter() { return !this.fixed && this.tableLayout.gutterWidth; } }, mapStates({ columns: 'columns', isAllSelected: 'isAllSelected', leftFixedLeafCount: 'fixedLeafColumnsLength', rightFixedLeafCount: 'rightFixedLeafColumnsLength', columnsCount: function columnsCount(states) { return states.columns.length; }, leftFixedCount: function leftFixedCount(states) { return states.fixedColumns.length; }, rightFixedCount: function rightFixedCount(states) { return states.rightFixedColumns.length; } })), methods: { isCellHidden: function isCellHidden(index, columns, column) { if (this.fixed === true || this.fixed === 'left') { return index >= this.leftFixedLeafCount; } else if (this.fixed === 'right') { var before = 0; for (var i = 0; i < index; i++) { before += columns[i].colSpan; } return before < this.columnsCount - this.rightFixedLeafCount; } else if (!this.fixed && column.fixed) { // hide cell when footer instance is not fixed and column is fixed return true; } else { return index < this.leftFixedCount || index >= this.columnsCount - this.rightFixedCount; } }, getRowClasses: function getRowClasses(column, cellIndex) { var classes = [column.id, column.align, column.labelClassName]; if (column.className) { classes.push(column.className); } if (this.isCellHidden(cellIndex, this.columns, column)) { classes.push('is-hidden'); } if (!column.children) { classes.push('is-leaf'); } return classes; } } }); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/table/src/table.vue?vue&type=script&lang=js& var tablevue_type_script_lang_js_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var tableIdSeed = 1; /* harmony default export */ var tablevue_type_script_lang_js_ = ({ name: 'ElTable', mixins: [locale_default.a, migrating_default.a], directives: { Mousewheel: directives_mousewheel }, props: { data: { type: Array, default: function _default() { return []; } }, size: String, width: [String, Number], height: [String, Number], maxHeight: [String, Number], fit: { type: Boolean, default: true }, stripe: Boolean, border: Boolean, rowKey: [String, Function], context: {}, showHeader: { type: Boolean, default: true }, showSummary: Boolean, sumText: String, summaryMethod: Function, rowClassName: [String, Function], rowStyle: [Object, Function], cellClassName: [String, Function], cellStyle: [Object, Function], headerRowClassName: [String, Function], headerRowStyle: [Object, Function], headerCellClassName: [String, Function], headerCellStyle: [Object, Function], highlightCurrentRow: Boolean, currentRowKey: [String, Number], emptyText: String, expandRowKeys: Array, defaultExpandAll: Boolean, defaultSort: Object, tooltipEffect: String, spanMethod: Function, selectOnIndeterminate: { type: Boolean, default: true }, indent: { type: Number, default: 16 }, treeProps: { type: Object, default: function _default() { return { hasChildren: 'hasChildren', children: 'children' }; } }, lazy: Boolean, load: Function }, components: { TableHeader: table_header, TableFooter: table_footer, TableBody: table_body, ElCheckbox: checkbox_default.a }, methods: { getMigratingConfig: function getMigratingConfig() { return { events: { expand: 'expand is renamed to expand-change' } }; }, setCurrentRow: function setCurrentRow(row) { this.store.commit('setCurrentRow', row); }, toggleRowSelection: function toggleRowSelection(row, selected) { this.store.toggleRowSelection(row, selected, false); this.store.updateAllSelected(); }, toggleRowExpansion: function toggleRowExpansion(row, expanded) { this.store.toggleRowExpansionAdapter(row, expanded); }, clearSelection: function clearSelection() { this.store.clearSelection(); }, clearFilter: function clearFilter(columnKeys) { this.store.clearFilter(columnKeys); }, clearSort: function clearSort() { this.store.clearSort(); }, handleMouseLeave: function handleMouseLeave() { this.store.commit('setHoverRow', null); if (this.hoverState) this.hoverState = null; }, updateScrollY: function updateScrollY() { var changed = this.layout.updateScrollY(); if (changed) { this.layout.notifyObservers('scrollable'); this.layout.updateColumnsWidth(); } }, handleFixedMousewheel: function handleFixedMousewheel(event, data) { var bodyWrapper = this.bodyWrapper; if (Math.abs(data.spinY) > 0) { var currentScrollTop = bodyWrapper.scrollTop; if (data.pixelY < 0 && currentScrollTop !== 0) { event.preventDefault(); } if (data.pixelY > 0 && bodyWrapper.scrollHeight - bodyWrapper.clientHeight > currentScrollTop) { event.preventDefault(); } bodyWrapper.scrollTop += Math.ceil(data.pixelY / 5); } else { bodyWrapper.scrollLeft += Math.ceil(data.pixelX / 5); } }, handleHeaderFooterMousewheel: function handleHeaderFooterMousewheel(event, data) { var pixelX = data.pixelX, pixelY = data.pixelY; if (Math.abs(pixelX) >= Math.abs(pixelY)) { this.bodyWrapper.scrollLeft += data.pixelX / 5; } }, // TODO 使用 CSS transform syncPostion: Object(external_throttle_debounce_["throttle"])(20, function () { var _bodyWrapper = this.bodyWrapper, scrollLeft = _bodyWrapper.scrollLeft, scrollTop = _bodyWrapper.scrollTop, offsetWidth = _bodyWrapper.offsetWidth, scrollWidth = _bodyWrapper.scrollWidth; var _$refs = this.$refs, headerWrapper = _$refs.headerWrapper, footerWrapper = _$refs.footerWrapper, fixedBodyWrapper = _$refs.fixedBodyWrapper, rightFixedBodyWrapper = _$refs.rightFixedBodyWrapper; if (headerWrapper) headerWrapper.scrollLeft = scrollLeft; if (footerWrapper) footerWrapper.scrollLeft = scrollLeft; if (fixedBodyWrapper) fixedBodyWrapper.scrollTop = scrollTop; if (rightFixedBodyWrapper) rightFixedBodyWrapper.scrollTop = scrollTop; var maxScrollLeftPosition = scrollWidth - offsetWidth - 1; if (scrollLeft >= maxScrollLeftPosition) { this.scrollPosition = 'right'; } else if (scrollLeft === 0) { this.scrollPosition = 'left'; } else { this.scrollPosition = 'middle'; } }), bindEvents: function bindEvents() { this.bodyWrapper.addEventListener('scroll', this.syncPostion, { passive: true }); if (this.fit) { Object(resize_event_["addResizeListener"])(this.$el, this.resizeListener); } }, unbindEvents: function unbindEvents() { this.bodyWrapper.removeEventListener('scroll', this.syncPostion, { passive: true }); if (this.fit) { Object(resize_event_["removeResizeListener"])(this.$el, this.resizeListener); } }, resizeListener: function resizeListener() { if (!this.$ready) return; var shouldUpdateLayout = false; var el = this.$el; var _resizeState = this.resizeState, oldWidth = _resizeState.width, oldHeight = _resizeState.height; var width = el.offsetWidth; if (oldWidth !== width) { shouldUpdateLayout = true; } var height = el.offsetHeight; if ((this.height || this.shouldUpdateHeight) && oldHeight !== height) { shouldUpdateLayout = true; } if (shouldUpdateLayout) { this.resizeState.width = width; this.resizeState.height = height; this.doLayout(); } }, doLayout: function doLayout() { if (this.shouldUpdateHeight) { this.layout.updateElsHeight(); } this.layout.updateColumnsWidth(); }, sort: function sort(prop, order) { this.store.commit('sort', { prop: prop, order: order }); }, toggleAllSelection: function toggleAllSelection() { this.store.commit('toggleAllSelection'); } }, computed: tablevue_type_script_lang_js_extends({ tableSize: function tableSize() { return this.size || (this.$ELEMENT || {}).size; }, bodyWrapper: function bodyWrapper() { return this.$refs.bodyWrapper; }, shouldUpdateHeight: function shouldUpdateHeight() { return this.height || this.maxHeight || this.fixedColumns.length > 0 || this.rightFixedColumns.length > 0; }, bodyWidth: function bodyWidth() { var _layout = this.layout, bodyWidth = _layout.bodyWidth, scrollY = _layout.scrollY, gutterWidth = _layout.gutterWidth; return bodyWidth ? bodyWidth - (scrollY ? gutterWidth : 0) + 'px' : ''; }, bodyHeight: function bodyHeight() { var _layout2 = this.layout, _layout2$headerHeight = _layout2.headerHeight, headerHeight = _layout2$headerHeight === undefined ? 0 : _layout2$headerHeight, bodyHeight = _layout2.bodyHeight, _layout2$footerHeight = _layout2.footerHeight, footerHeight = _layout2$footerHeight === undefined ? 0 : _layout2$footerHeight; if (this.height) { return { height: bodyHeight ? bodyHeight + 'px' : '' }; } else if (this.maxHeight) { var maxHeight = parseHeight(this.maxHeight); if (typeof maxHeight === 'number') { return { 'max-height': maxHeight - footerHeight - (this.showHeader ? headerHeight : 0) + 'px' }; } } return {}; }, fixedBodyHeight: function fixedBodyHeight() { if (this.height) { return { height: this.layout.fixedBodyHeight ? this.layout.fixedBodyHeight + 'px' : '' }; } else if (this.maxHeight) { var maxHeight = parseHeight(this.maxHeight); if (typeof maxHeight === 'number') { maxHeight = this.layout.scrollX ? maxHeight - this.layout.gutterWidth : maxHeight; if (this.showHeader) { maxHeight -= this.layout.headerHeight; } maxHeight -= this.layout.footerHeight; return { 'max-height': maxHeight + 'px' }; } } return {}; }, fixedHeight: function fixedHeight() { if (this.maxHeight) { if (this.showSummary) { return { bottom: 0 }; } return { bottom: this.layout.scrollX && this.data.length ? this.layout.gutterWidth + 'px' : '' }; } else { if (this.showSummary) { return { height: this.layout.tableHeight ? this.layout.tableHeight + 'px' : '' }; } return { height: this.layout.viewportHeight ? this.layout.viewportHeight + 'px' : '' }; } }, emptyBlockStyle: function emptyBlockStyle() { if (this.data && this.data.length) return null; var height = '100%'; if (this.layout.appendHeight) { height = 'calc(100% - ' + this.layout.appendHeight + 'px)'; } return { width: this.bodyWidth, height: height }; } }, mapStates({ selection: 'selection', columns: 'columns', tableData: 'data', fixedColumns: 'fixedColumns', rightFixedColumns: 'rightFixedColumns' })), watch: { height: { immediate: true, handler: function handler(value) { this.layout.setHeight(value); } }, maxHeight: { immediate: true, handler: function handler(value) { this.layout.setMaxHeight(value); } }, currentRowKey: { immediate: true, handler: function handler(value) { if (!this.rowKey) return; this.store.setCurrentRowKey(value); } }, data: { immediate: true, handler: function handler(value) { this.store.commit('setData', value); } }, expandRowKeys: { immediate: true, handler: function handler(newVal) { if (newVal) { this.store.setExpandRowKeysAdapter(newVal); } } } }, created: function created() { var _this = this; this.tableId = 'el-table_' + tableIdSeed++; this.debouncedUpdateLayout = Object(external_throttle_debounce_["debounce"])(50, function () { return _this.doLayout(); }); }, mounted: function mounted() { var _this2 = this; this.bindEvents(); this.store.updateColumns(); this.doLayout(); this.resizeState = { width: this.$el.offsetWidth, height: this.$el.offsetHeight }; // init filters this.store.states.columns.forEach(function (column) { if (column.filteredValue && column.filteredValue.length) { _this2.store.commit('filterChange', { column: column, values: column.filteredValue, silent: true }); } }); this.$ready = true; }, destroyed: function destroyed() { this.unbindEvents(); }, data: function data() { var _treeProps = this.treeProps, _treeProps$hasChildre = _treeProps.hasChildren, hasChildren = _treeProps$hasChildre === undefined ? 'hasChildren' : _treeProps$hasChildre, _treeProps$children = _treeProps.children, children = _treeProps$children === undefined ? 'children' : _treeProps$children; this.store = createStore(this, { rowKey: this.rowKey, defaultExpandAll: this.defaultExpandAll, selectOnIndeterminate: this.selectOnIndeterminate, // TreeTable 的相关配置 indent: this.indent, lazy: this.lazy, lazyColumnIdentifier: hasChildren, childrenColumnName: children }); var layout = new table_layout({ store: this.store, table: this, fit: this.fit, showHeader: this.showHeader }); return { layout: layout, isHidden: false, renderExpanded: null, resizeProxyVisible: false, resizeState: { width: null, height: null }, // 是否拥有多级表头 isGroup: false, scrollPosition: 'left' }; } }); // CONCATENATED MODULE: ./packages/table/src/table.vue?vue&type=script&lang=js& /* harmony default export */ var src_tablevue_type_script_lang_js_ = (tablevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/table/src/table.vue /* normalize component */ var table_component = normalizeComponent( src_tablevue_type_script_lang_js_, tablevue_type_template_id_493fe34e_render, tablevue_type_template_id_493fe34e_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var table_api; } table_component.options.__file = "packages/table/src/table.vue" /* harmony default export */ var src_table = (table_component.exports); // CONCATENATED MODULE: ./packages/table/index.js /* istanbul ignore next */ src_table.install = function (Vue) { Vue.component(src_table.name, src_table); }; /* harmony default export */ var packages_table = (src_table); // CONCATENATED MODULE: ./packages/table/src/config.js var cellStarts = { default: { order: '' }, selection: { width: 48, minWidth: 48, realWidth: 48, order: '', className: 'el-table-column--selection' }, expand: { width: 48, minWidth: 48, realWidth: 48, order: '' }, index: { width: 48, minWidth: 48, realWidth: 48, order: '' } }; // 这些选项不应该被覆盖 var cellForced = { selection: { renderHeader: function renderHeader(h, _ref) { var store = _ref.store; return h('el-checkbox', { attrs: { disabled: store.states.data && store.states.data.length === 0, indeterminate: store.states.selection.length > 0 && !this.isAllSelected, value: this.isAllSelected }, nativeOn: { 'click': this.toggleAllSelection } }); }, renderCell: function renderCell(h, _ref2) { var row = _ref2.row, column = _ref2.column, store = _ref2.store, $index = _ref2.$index; return h('el-checkbox', { nativeOn: { 'click': function click(event) { return event.stopPropagation(); } }, attrs: { value: store.isSelected(row), disabled: column.selectable ? !column.selectable.call(null, row, $index) : false }, on: { 'input': function input() { store.commit('rowSelectedChanged', row); } } }); }, sortable: false, resizable: false }, index: { renderHeader: function renderHeader(h, _ref3) { var column = _ref3.column; return column.label || '#'; }, renderCell: function renderCell(h, _ref4) { var $index = _ref4.$index, column = _ref4.column; var i = $index + 1; var index = column.index; if (typeof index === 'number') { i = $index + index; } else if (typeof index === 'function') { i = index($index); } return h('div', [i]); }, sortable: false }, expand: { renderHeader: function renderHeader(h, _ref5) { var column = _ref5.column; return column.label || ''; }, renderCell: function renderCell(h, _ref6) { var row = _ref6.row, store = _ref6.store; var classes = ['el-table__expand-icon']; if (store.states.expandRows.indexOf(row) > -1) { classes.push('el-table__expand-icon--expanded'); } var callback = function callback(e) { e.stopPropagation(); store.toggleRowExpansion(row); }; return h( 'div', { 'class': classes, on: { 'click': callback } }, [h('i', { 'class': 'el-icon el-icon-arrow-right' })] ); }, sortable: false, resizable: false, className: 'el-table__expand-column' } }; function defaultRenderCell(h, _ref7) { var row = _ref7.row, column = _ref7.column, $index = _ref7.$index; var property = column.property; var value = property && Object(util_["getPropByPath"])(row, property).v; if (column && column.formatter) { return column.formatter(row, column, value, $index); } return value; } function treeCellPrefix(h, _ref8) { var row = _ref8.row, treeNode = _ref8.treeNode, store = _ref8.store; if (!treeNode) return null; var ele = []; var callback = function callback(e) { e.stopPropagation(); store.loadOrToggle(row); }; if (treeNode.indent) { ele.push(h('span', { 'class': 'el-table__indent', style: { 'padding-left': treeNode.indent + 'px' } })); } if (typeof treeNode.expanded === 'boolean' && !treeNode.noLazyChildren) { var expandClasses = ['el-table__expand-icon', treeNode.expanded ? 'el-table__expand-icon--expanded' : '']; var iconClasses = ['el-icon-arrow-right']; if (treeNode.loading) { iconClasses = ['el-icon-loading']; } ele.push(h( 'div', { 'class': expandClasses, on: { 'click': callback } }, [h('i', { 'class': iconClasses })] )); } else { ele.push(h('span', { 'class': 'el-table__placeholder' })); } return ele; } // CONCATENATED MODULE: ./packages/table/src/table-column.js var table_column_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var columnIdSeed = 1; /* harmony default export */ var table_column = ({ name: 'ElTableColumn', props: { type: { type: String, default: 'default' }, label: String, className: String, labelClassName: String, property: String, prop: String, width: {}, minWidth: {}, renderHeader: Function, sortable: { type: [Boolean, String], default: false }, sortMethod: Function, sortBy: [String, Function, Array], resizable: { type: Boolean, default: true }, columnKey: String, align: String, headerAlign: String, showTooltipWhenOverflow: Boolean, showOverflowTooltip: Boolean, fixed: [Boolean, String], formatter: Function, selectable: Function, reserveSelection: Boolean, filterMethod: Function, filteredValue: Array, filters: Array, filterPlacement: String, filterMultiple: { type: Boolean, default: true }, index: [Number, Function], sortOrders: { type: Array, default: function _default() { return ['ascending', 'descending', null]; }, validator: function validator(val) { return val.every(function (order) { return ['ascending', 'descending', null].indexOf(order) > -1; }); } } }, data: function data() { return { isSubColumn: false, columns: [] }; }, computed: { owner: function owner() { var parent = this.$parent; while (parent && !parent.tableId) { parent = parent.$parent; } return parent; }, columnOrTableParent: function columnOrTableParent() { var parent = this.$parent; while (parent && !parent.tableId && !parent.columnId) { parent = parent.$parent; } return parent; }, realWidth: function realWidth() { return parseWidth(this.width); }, realMinWidth: function realMinWidth() { return parseMinWidth(this.minWidth); }, realAlign: function realAlign() { return this.align ? 'is-' + this.align : null; }, realHeaderAlign: function realHeaderAlign() { return this.headerAlign ? 'is-' + this.headerAlign : this.realAlign; } }, methods: { getPropsData: function getPropsData() { var _this = this; for (var _len = arguments.length, props = Array(_len), _key = 0; _key < _len; _key++) { props[_key] = arguments[_key]; } return props.reduce(function (prev, cur) { if (Array.isArray(cur)) { cur.forEach(function (key) { prev[key] = _this[key]; }); } return prev; }, {}); }, getColumnElIndex: function getColumnElIndex(children, child) { return [].indexOf.call(children, child); }, setColumnWidth: function setColumnWidth(column) { if (this.realWidth) { column.width = this.realWidth; } if (this.realMinWidth) { column.minWidth = this.realMinWidth; } if (!column.minWidth) { column.minWidth = 80; } column.realWidth = column.width === undefined ? column.minWidth : column.width; return column; }, setColumnForcedProps: function setColumnForcedProps(column) { // 对于特定类型的 column,某些属性不允许设置 var type = column.type; var source = cellForced[type] || {}; Object.keys(source).forEach(function (prop) { var value = source[prop]; if (value !== undefined) { column[prop] = prop === 'className' ? column[prop] + ' ' + value : value; } }); return column; }, setColumnRenders: function setColumnRenders(column) { var _this2 = this; var h = this.$createElement; // renderHeader 属性不推荐使用。 if (this.renderHeader) { console.warn('[Element Warn][TableColumn]Comparing to render-header, scoped-slot header is easier to use. We recommend users to use scoped-slot header.'); } else if (column.type !== 'selection') { column.renderHeader = function (h, scope) { var renderHeader = _this2.$scopedSlots.header; return renderHeader ? renderHeader(scope) : column.label; }; } var originRenderCell = column.renderCell; // TODO: 这里的实现调整 if (column.type === 'expand') { // 对于展开行,renderCell 不允许配置的。在上一步中已经设置过,这里需要简单封装一下。 column.renderCell = function (h, data) { return h( 'div', { 'class': 'cell' }, [originRenderCell(h, data)] ); }; this.owner.renderExpanded = function (h, data) { return _this2.$scopedSlots.default ? _this2.$scopedSlots.default(data) : _this2.$slots.default; }; } else { originRenderCell = originRenderCell || defaultRenderCell; // 对 renderCell 进行包装 column.renderCell = function (h, data) { var children = null; if (_this2.$scopedSlots.default) { children = _this2.$scopedSlots.default(data); } else { children = originRenderCell(h, data); } var prefix = treeCellPrefix(h, data); var props = { class: 'cell', style: {} }; if (column.showOverflowTooltip) { props.class += ' el-tooltip'; props.style = { width: (data.column.realWidth || data.column.width) - 1 + 'px' }; } return h( 'div', props, [prefix, children] ); }; } return column; }, registerNormalWatchers: function registerNormalWatchers() { var _this3 = this; var props = ['label', 'property', 'filters', 'filterMultiple', 'sortable', 'index', 'formatter', 'className', 'labelClassName', 'showOverflowTooltip']; // 一些属性具有别名 var aliases = { prop: 'property', realAlign: 'align', realHeaderAlign: 'headerAlign', realWidth: 'width' }; var allAliases = props.reduce(function (prev, cur) { prev[cur] = cur; return prev; }, aliases); Object.keys(allAliases).forEach(function (key) { var columnKey = aliases[key]; _this3.$watch(key, function (newVal) { _this3.columnConfig[columnKey] = newVal; }); }); }, registerComplexWatchers: function registerComplexWatchers() { var _this4 = this; var props = ['fixed']; var aliases = { realWidth: 'width', realMinWidth: 'minWidth' }; var allAliases = props.reduce(function (prev, cur) { prev[cur] = cur; return prev; }, aliases); Object.keys(allAliases).forEach(function (key) { var columnKey = aliases[key]; _this4.$watch(key, function (newVal) { _this4.columnConfig[columnKey] = newVal; var updateColumns = columnKey === 'fixed'; _this4.owner.store.scheduleLayout(updateColumns); }); }); } }, components: { ElCheckbox: checkbox_default.a }, beforeCreate: function beforeCreate() { this.row = {}; this.column = {}; this.$index = 0; this.columnId = ''; }, created: function created() { var parent = this.columnOrTableParent; this.isSubColumn = this.owner !== parent; this.columnId = (parent.tableId || parent.columnId) + '_column_' + columnIdSeed++; var type = this.type || 'default'; var sortable = this.sortable === '' ? true : this.sortable; var defaults = table_column_extends({}, cellStarts[type], { id: this.columnId, type: type, property: this.prop || this.property, align: this.realAlign, headerAlign: this.realHeaderAlign, showOverflowTooltip: this.showOverflowTooltip || this.showTooltipWhenOverflow, // filter 相关属性 filterable: this.filters || this.filterMethod, filteredValue: [], filterPlacement: '', isColumnGroup: false, filterOpened: false, // sort 相关属性 sortable: sortable, // index 列 index: this.index }); var basicProps = ['columnKey', 'label', 'className', 'labelClassName', 'type', 'renderHeader', 'formatter', 'fixed', 'resizable']; var sortProps = ['sortMethod', 'sortBy', 'sortOrders']; var selectProps = ['selectable', 'reserveSelection']; var filterProps = ['filterMethod', 'filters', 'filterMultiple', 'filterOpened', 'filteredValue', 'filterPlacement']; var column = this.getPropsData(basicProps, sortProps, selectProps, filterProps); column = mergeOptions(defaults, column); // 注意 compose 中函数执行的顺序是从右到左 var chains = compose(this.setColumnRenders, this.setColumnWidth, this.setColumnForcedProps); column = chains(column); this.columnConfig = column; // 注册 watcher this.registerNormalWatchers(); this.registerComplexWatchers(); }, mounted: function mounted() { var owner = this.owner; var parent = this.columnOrTableParent; var children = this.isSubColumn ? parent.$el.children : parent.$refs.hiddenColumns.children; var columnIndex = this.getColumnElIndex(children, this.$el); owner.store.commit('insertColumn', this.columnConfig, columnIndex, this.isSubColumn ? parent.columnConfig : null); }, destroyed: function destroyed() { if (!this.$parent) return; var parent = this.$parent; this.owner.store.commit('removeColumn', this.columnConfig, this.isSubColumn ? parent.columnConfig : null); }, render: function render(h) { // slots 也要渲染,需要计算合并表头 return h('div', this.$slots.default); } }); // CONCATENATED MODULE: ./packages/table-column/index.js /* istanbul ignore next */ table_column.install = function (Vue) { Vue.component(table_column.name, table_column); }; /* harmony default export */ var packages_table_column = (table_column); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/picker.vue?vue&type=template&id=79ae069f& var pickervue_type_template_id_79ae069f_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return !_vm.ranged ? _c( "el-input", _vm._b( { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: _vm.handleClose, expression: "handleClose" } ], ref: "reference", staticClass: "el-date-editor", class: "el-date-editor--" + _vm.type, attrs: { readonly: !_vm.editable || _vm.readonly || _vm.type === "dates" || _vm.type === "week", disabled: _vm.pickerDisabled, size: _vm.pickerSize, name: _vm.name, placeholder: _vm.placeholder, value: _vm.displayValue, validateEvent: false }, on: { focus: _vm.handleFocus, input: function(value) { return (_vm.userInput = value) }, change: _vm.handleChange }, nativeOn: { keydown: function($event) { return _vm.handleKeydown($event) }, mouseenter: function($event) { return _vm.handleMouseEnter($event) }, mouseleave: function($event) { _vm.showClose = false } } }, "el-input", _vm.firstInputId, false ), [ _c("i", { staticClass: "el-input__icon", class: _vm.triggerClass, attrs: { slot: "prefix" }, on: { click: _vm.handleFocus }, slot: "prefix" }), _vm.haveTrigger ? _c("i", { staticClass: "el-input__icon", class: [_vm.showClose ? "" + _vm.clearIcon : ""], attrs: { slot: "suffix" }, on: { click: _vm.handleClickIcon }, slot: "suffix" }) : _vm._e() ] ) : _c( "div", { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: _vm.handleClose, expression: "handleClose" } ], ref: "reference", staticClass: "el-date-editor el-range-editor el-input__inner", class: [ "el-date-editor--" + _vm.type, _vm.pickerSize ? "el-range-editor--" + _vm.pickerSize : "", _vm.pickerDisabled ? "is-disabled" : "", _vm.pickerVisible ? "is-active" : "" ], on: { click: _vm.handleRangeClick, mouseenter: _vm.handleMouseEnter, mouseleave: function($event) { _vm.showClose = false }, keydown: _vm.handleKeydown } }, [ _c("i", { class: ["el-input__icon", "el-range__icon", _vm.triggerClass] }), _c( "input", _vm._b( { staticClass: "el-range-input", attrs: { autocomplete: "off", placeholder: _vm.startPlaceholder, disabled: _vm.pickerDisabled, readonly: !_vm.editable || _vm.readonly, name: _vm.name && _vm.name[0] }, domProps: { value: _vm.displayValue && _vm.displayValue[0] }, on: { input: _vm.handleStartInput, change: _vm.handleStartChange, focus: _vm.handleFocus } }, "input", _vm.firstInputId, false ) ), _vm._t("range-separator", [ _c("span", { staticClass: "el-range-separator" }, [ _vm._v(_vm._s(_vm.rangeSeparator)) ]) ]), _c( "input", _vm._b( { staticClass: "el-range-input", attrs: { autocomplete: "off", placeholder: _vm.endPlaceholder, disabled: _vm.pickerDisabled, readonly: !_vm.editable || _vm.readonly, name: _vm.name && _vm.name[1] }, domProps: { value: _vm.displayValue && _vm.displayValue[1] }, on: { input: _vm.handleEndInput, change: _vm.handleEndChange, focus: _vm.handleFocus } }, "input", _vm.secondInputId, false ) ), _vm.haveTrigger ? _c("i", { staticClass: "el-input__icon el-range__close-icon", class: [_vm.showClose ? "" + _vm.clearIcon : ""], on: { click: _vm.handleClickIcon } }) : _vm._e() ], 2 ) } var pickervue_type_template_id_79ae069f_staticRenderFns = [] pickervue_type_template_id_79ae069f_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/picker.vue?vue&type=template&id=79ae069f& // EXTERNAL MODULE: external "element-ui/lib/utils/date-util" var date_util_ = __webpack_require__(0); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/picker.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var NewPopper = { props: { appendToBody: vue_popper_default.a.props.appendToBody, offset: vue_popper_default.a.props.offset, boundariesPadding: vue_popper_default.a.props.boundariesPadding, arrowOffset: vue_popper_default.a.props.arrowOffset }, methods: vue_popper_default.a.methods, data: function data() { return merge_default()({ visibleArrow: true }, vue_popper_default.a.data); }, beforeDestroy: vue_popper_default.a.beforeDestroy }; var DEFAULT_FORMATS = { date: 'yyyy-MM-dd', month: 'yyyy-MM', datetime: 'yyyy-MM-dd HH:mm:ss', time: 'HH:mm:ss', week: 'yyyywWW', timerange: 'HH:mm:ss', daterange: 'yyyy-MM-dd', monthrange: 'yyyy-MM', datetimerange: 'yyyy-MM-dd HH:mm:ss', year: 'yyyy' }; var HAVE_TRIGGER_TYPES = ['date', 'datetime', 'time', 'time-select', 'week', 'month', 'year', 'daterange', 'monthrange', 'timerange', 'datetimerange', 'dates']; var pickervue_type_script_lang_js_DATE_FORMATTER = function DATE_FORMATTER(value, format) { if (format === 'timestamp') return value.getTime(); return Object(date_util_["formatDate"])(value, format); }; var pickervue_type_script_lang_js_DATE_PARSER = function DATE_PARSER(text, format) { if (format === 'timestamp') return new Date(Number(text)); return Object(date_util_["parseDate"])(text, format); }; var RANGE_FORMATTER = function RANGE_FORMATTER(value, format) { if (Array.isArray(value) && value.length === 2) { var start = value[0]; var end = value[1]; if (start && end) { return [pickervue_type_script_lang_js_DATE_FORMATTER(start, format), pickervue_type_script_lang_js_DATE_FORMATTER(end, format)]; } } return ''; }; var RANGE_PARSER = function RANGE_PARSER(array, format, separator) { if (!Array.isArray(array)) { array = array.split(separator); } if (array.length === 2) { var range1 = array[0]; var range2 = array[1]; return [pickervue_type_script_lang_js_DATE_PARSER(range1, format), pickervue_type_script_lang_js_DATE_PARSER(range2, format)]; } return []; }; var TYPE_VALUE_RESOLVER_MAP = { default: { formatter: function formatter(value) { if (!value) return ''; return '' + value; }, parser: function parser(text) { if (text === undefined || text === '') return null; return text; } }, week: { formatter: function formatter(value, format) { var week = Object(date_util_["getWeekNumber"])(value); var month = value.getMonth(); var trueDate = new Date(value); if (week === 1 && month === 11) { trueDate.setHours(0, 0, 0, 0); trueDate.setDate(trueDate.getDate() + 3 - (trueDate.getDay() + 6) % 7); } var date = Object(date_util_["formatDate"])(trueDate, format); date = /WW/.test(date) ? date.replace(/WW/, week < 10 ? '0' + week : week) : date.replace(/W/, week); return date; }, parser: function parser(text, format) { // parse as if a normal date return TYPE_VALUE_RESOLVER_MAP.date.parser(text, format); } }, date: { formatter: pickervue_type_script_lang_js_DATE_FORMATTER, parser: pickervue_type_script_lang_js_DATE_PARSER }, datetime: { formatter: pickervue_type_script_lang_js_DATE_FORMATTER, parser: pickervue_type_script_lang_js_DATE_PARSER }, daterange: { formatter: RANGE_FORMATTER, parser: RANGE_PARSER }, monthrange: { formatter: RANGE_FORMATTER, parser: RANGE_PARSER }, datetimerange: { formatter: RANGE_FORMATTER, parser: RANGE_PARSER }, timerange: { formatter: RANGE_FORMATTER, parser: RANGE_PARSER }, time: { formatter: pickervue_type_script_lang_js_DATE_FORMATTER, parser: pickervue_type_script_lang_js_DATE_PARSER }, month: { formatter: pickervue_type_script_lang_js_DATE_FORMATTER, parser: pickervue_type_script_lang_js_DATE_PARSER }, year: { formatter: pickervue_type_script_lang_js_DATE_FORMATTER, parser: pickervue_type_script_lang_js_DATE_PARSER }, number: { formatter: function formatter(value) { if (!value) return ''; return '' + value; }, parser: function parser(text) { var result = Number(text); if (!isNaN(text)) { return result; } else { return null; } } }, dates: { formatter: function formatter(value, format) { return value.map(function (date) { return pickervue_type_script_lang_js_DATE_FORMATTER(date, format); }); }, parser: function parser(value, format) { return (typeof value === 'string' ? value.split(', ') : value).map(function (date) { return date instanceof Date ? date : pickervue_type_script_lang_js_DATE_PARSER(date, format); }); } } }; var PLACEMENT_MAP = { left: 'bottom-start', center: 'bottom', right: 'bottom-end' }; var parseAsFormatAndType = function parseAsFormatAndType(value, customFormat, type) { var rangeSeparator = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : '-'; if (!value) return null; var parser = (TYPE_VALUE_RESOLVER_MAP[type] || TYPE_VALUE_RESOLVER_MAP['default']).parser; var format = customFormat || DEFAULT_FORMATS[type]; return parser(value, format, rangeSeparator); }; var formatAsFormatAndType = function formatAsFormatAndType(value, customFormat, type) { if (!value) return null; var formatter = (TYPE_VALUE_RESOLVER_MAP[type] || TYPE_VALUE_RESOLVER_MAP['default']).formatter; var format = customFormat || DEFAULT_FORMATS[type]; return formatter(value, format); }; /* * Considers: * 1. Date object * 2. date string * 3. array of 1 or 2 */ var valueEquals = function valueEquals(a, b) { // considers Date object and string var dateEquals = function dateEquals(a, b) { var aIsDate = a instanceof Date; var bIsDate = b instanceof Date; if (aIsDate && bIsDate) { return a.getTime() === b.getTime(); } if (!aIsDate && !bIsDate) { return a === b; } return false; }; var aIsArray = a instanceof Array; var bIsArray = b instanceof Array; if (aIsArray && bIsArray) { if (a.length !== b.length) { return false; } return a.every(function (item, index) { return dateEquals(item, b[index]); }); } if (!aIsArray && !bIsArray) { return dateEquals(a, b); } return false; }; var isString = function isString(val) { return typeof val === 'string' || val instanceof String; }; var pickervue_type_script_lang_js_validator = function validator(val) { // either: String, Array of String, null / undefined return val === null || val === undefined || isString(val) || Array.isArray(val) && val.length === 2 && val.every(isString); }; /* harmony default export */ var pickervue_type_script_lang_js_ = ({ mixins: [emitter_default.a, NewPopper], inject: { elForm: { default: '' }, elFormItem: { default: '' } }, props: { size: String, format: String, valueFormat: String, readonly: Boolean, placeholder: String, startPlaceholder: String, endPlaceholder: String, prefixIcon: String, clearIcon: { type: String, default: 'el-icon-circle-close' }, name: { default: '', validator: pickervue_type_script_lang_js_validator }, disabled: Boolean, clearable: { type: Boolean, default: true }, id: { default: '', validator: pickervue_type_script_lang_js_validator }, popperClass: String, editable: { type: Boolean, default: true }, align: { type: String, default: 'left' }, value: {}, defaultValue: {}, defaultTime: {}, rangeSeparator: { default: '-' }, pickerOptions: {}, unlinkPanels: Boolean, validateEvent: { type: Boolean, default: true } }, components: { ElInput: input_default.a }, directives: { Clickoutside: clickoutside_default.a }, data: function data() { return { pickerVisible: false, showClose: false, userInput: null, valueOnOpen: null, // value when picker opens, used to determine whether to emit change unwatchPickerOptions: null }; }, watch: { pickerVisible: function pickerVisible(val) { if (this.readonly || this.pickerDisabled) return; if (val) { this.showPicker(); this.valueOnOpen = Array.isArray(this.value) ? [].concat(this.value) : this.value; } else { this.hidePicker(); this.emitChange(this.value); this.userInput = null; if (this.validateEvent) { this.dispatch('ElFormItem', 'el.form.blur'); } this.$emit('blur', this); this.blur(); } }, parsedValue: { immediate: true, handler: function handler(val) { if (this.picker) { this.picker.value = val; } } }, defaultValue: function defaultValue(val) { // NOTE: should eventually move to jsx style picker + panel ? if (this.picker) { this.picker.defaultValue = val; } }, value: function value(val, oldVal) { if (!valueEquals(val, oldVal) && !this.pickerVisible && this.validateEvent) { this.dispatch('ElFormItem', 'el.form.change', val); } } }, computed: { ranged: function ranged() { return this.type.indexOf('range') > -1; }, reference: function reference() { var reference = this.$refs.reference; return reference.$el || reference; }, refInput: function refInput() { if (this.reference) { return [].slice.call(this.reference.querySelectorAll('input')); } return []; }, valueIsEmpty: function valueIsEmpty() { var val = this.value; if (Array.isArray(val)) { for (var i = 0, len = val.length; i < len; i++) { if (val[i]) { return false; } } } else { if (val) { return false; } } return true; }, triggerClass: function triggerClass() { return this.prefixIcon || (this.type.indexOf('time') !== -1 ? 'el-icon-time' : 'el-icon-date'); }, selectionMode: function selectionMode() { if (this.type === 'week') { return 'week'; } else if (this.type === 'month') { return 'month'; } else if (this.type === 'year') { return 'year'; } else if (this.type === 'dates') { return 'dates'; } return 'day'; }, haveTrigger: function haveTrigger() { if (typeof this.showTrigger !== 'undefined') { return this.showTrigger; } return HAVE_TRIGGER_TYPES.indexOf(this.type) !== -1; }, displayValue: function displayValue() { var formattedValue = formatAsFormatAndType(this.parsedValue, this.format, this.type, this.rangeSeparator); if (Array.isArray(this.userInput)) { return [this.userInput[0] || formattedValue && formattedValue[0] || '', this.userInput[1] || formattedValue && formattedValue[1] || '']; } else if (this.userInput !== null) { return this.userInput; } else if (formattedValue) { return this.type === 'dates' ? formattedValue.join(', ') : formattedValue; } else { return ''; } }, parsedValue: function parsedValue() { if (!this.value) return this.value; // component value is not set if (this.type === 'time-select') return this.value; // time-select does not require parsing, this might change in next major version var valueIsDateObject = Object(date_util_["isDateObject"])(this.value) || Array.isArray(this.value) && this.value.every(date_util_["isDateObject"]); if (valueIsDateObject) { return this.value; } if (this.valueFormat) { return parseAsFormatAndType(this.value, this.valueFormat, this.type, this.rangeSeparator) || this.value; } // NOTE: deal with common but incorrect usage, should remove in next major version // user might provide string / timestamp without value-format, coerce them into date (or array of date) return Array.isArray(this.value) ? this.value.map(function (val) { return new Date(val); }) : new Date(this.value); }, _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, pickerSize: function pickerSize() { return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; }, pickerDisabled: function pickerDisabled() { return this.disabled || (this.elForm || {}).disabled; }, firstInputId: function firstInputId() { var obj = {}; var id = void 0; if (this.ranged) { id = this.id && this.id[0]; } else { id = this.id; } if (id) obj.id = id; return obj; }, secondInputId: function secondInputId() { var obj = {}; var id = void 0; if (this.ranged) { id = this.id && this.id[1]; } if (id) obj.id = id; return obj; } }, created: function created() { // vue-popper this.popperOptions = { boundariesPadding: 0, gpuAcceleration: false }; this.placement = PLACEMENT_MAP[this.align] || PLACEMENT_MAP.left; this.$on('fieldReset', this.handleFieldReset); }, methods: { focus: function focus() { if (!this.ranged) { this.$refs.reference.focus(); } else { this.handleFocus(); } }, blur: function blur() { this.refInput.forEach(function (input) { return input.blur(); }); }, // {parse, formatTo} Value deals maps component value with internal Date parseValue: function parseValue(value) { var isParsed = Object(date_util_["isDateObject"])(value) || Array.isArray(value) && value.every(date_util_["isDateObject"]); if (this.valueFormat && !isParsed) { return parseAsFormatAndType(value, this.valueFormat, this.type, this.rangeSeparator) || value; } else { return value; } }, formatToValue: function formatToValue(date) { var isFormattable = Object(date_util_["isDateObject"])(date) || Array.isArray(date) && date.every(date_util_["isDateObject"]); if (this.valueFormat && isFormattable) { return formatAsFormatAndType(date, this.valueFormat, this.type, this.rangeSeparator); } else { return date; } }, // {parse, formatTo} String deals with user input parseString: function parseString(value) { var type = Array.isArray(value) ? this.type : this.type.replace('range', ''); return parseAsFormatAndType(value, this.format, type); }, formatToString: function formatToString(value) { var type = Array.isArray(value) ? this.type : this.type.replace('range', ''); return formatAsFormatAndType(value, this.format, type); }, handleMouseEnter: function handleMouseEnter() { if (this.readonly || this.pickerDisabled) return; if (!this.valueIsEmpty && this.clearable) { this.showClose = true; } }, handleChange: function handleChange() { if (this.userInput) { var value = this.parseString(this.displayValue); if (value) { this.picker.value = value; if (this.isValidValue(value)) { this.emitInput(value); this.userInput = null; } } } if (this.userInput === '') { this.emitInput(null); this.emitChange(null); this.userInput = null; } }, handleStartInput: function handleStartInput(event) { if (this.userInput) { this.userInput = [event.target.value, this.userInput[1]]; } else { this.userInput = [event.target.value, null]; } }, handleEndInput: function handleEndInput(event) { if (this.userInput) { this.userInput = [this.userInput[0], event.target.value]; } else { this.userInput = [null, event.target.value]; } }, handleStartChange: function handleStartChange(event) { var value = this.parseString(this.userInput && this.userInput[0]); if (value) { this.userInput = [this.formatToString(value), this.displayValue[1]]; var newValue = [value, this.picker.value && this.picker.value[1]]; this.picker.value = newValue; if (this.isValidValue(newValue)) { this.emitInput(newValue); this.userInput = null; } } }, handleEndChange: function handleEndChange(event) { var value = this.parseString(this.userInput && this.userInput[1]); if (value) { this.userInput = [this.displayValue[0], this.formatToString(value)]; var newValue = [this.picker.value && this.picker.value[0], value]; this.picker.value = newValue; if (this.isValidValue(newValue)) { this.emitInput(newValue); this.userInput = null; } } }, handleClickIcon: function handleClickIcon(event) { if (this.readonly || this.pickerDisabled) return; if (this.showClose) { this.valueOnOpen = this.value; event.stopPropagation(); this.emitInput(null); this.emitChange(null); this.showClose = false; if (this.picker && typeof this.picker.handleClear === 'function') { this.picker.handleClear(); } } else { this.pickerVisible = !this.pickerVisible; } }, handleClose: function handleClose() { if (!this.pickerVisible) return; this.pickerVisible = false; if (this.type === 'dates') { // restore to former value var oldValue = parseAsFormatAndType(this.valueOnOpen, this.valueFormat, this.type, this.rangeSeparator) || this.valueOnOpen; this.emitInput(oldValue); } }, handleFieldReset: function handleFieldReset(initialValue) { this.userInput = initialValue === '' ? null : initialValue; }, handleFocus: function handleFocus() { var type = this.type; if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) { this.pickerVisible = true; } this.$emit('focus', this); }, handleKeydown: function handleKeydown(event) { var _this = this; var keyCode = event.keyCode; // ESC if (keyCode === 27) { this.pickerVisible = false; event.stopPropagation(); return; } // Tab if (keyCode === 9) { if (!this.ranged) { this.handleChange(); this.pickerVisible = this.picker.visible = false; this.blur(); event.stopPropagation(); } else { // user may change focus between two input setTimeout(function () { if (_this.refInput.indexOf(document.activeElement) === -1) { _this.pickerVisible = false; _this.blur(); event.stopPropagation(); } }, 0); } return; } // Enter if (keyCode === 13) { if (this.userInput === '' || this.isValidValue(this.parseString(this.displayValue))) { this.handleChange(); this.pickerVisible = this.picker.visible = false; this.blur(); } event.stopPropagation(); return; } // if user is typing, do not let picker handle key input if (this.userInput) { event.stopPropagation(); return; } // delegate other keys to panel if (this.picker && this.picker.handleKeydown) { this.picker.handleKeydown(event); } }, handleRangeClick: function handleRangeClick() { var type = this.type; if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) { this.pickerVisible = true; } this.$emit('focus', this); }, hidePicker: function hidePicker() { if (this.picker) { this.picker.resetView && this.picker.resetView(); this.pickerVisible = this.picker.visible = false; this.destroyPopper(); } }, showPicker: function showPicker() { var _this2 = this; if (this.$isServer) return; if (!this.picker) { this.mountPicker(); } this.pickerVisible = this.picker.visible = true; this.updatePopper(); this.picker.value = this.parsedValue; this.picker.resetView && this.picker.resetView(); this.$nextTick(function () { _this2.picker.adjustSpinners && _this2.picker.adjustSpinners(); }); }, mountPicker: function mountPicker() { var _this3 = this; this.picker = new external_vue_default.a(this.panel).$mount(); this.picker.defaultValue = this.defaultValue; this.picker.defaultTime = this.defaultTime; this.picker.popperClass = this.popperClass; this.popperElm = this.picker.$el; this.picker.width = this.reference.getBoundingClientRect().width; this.picker.showTime = this.type === 'datetime' || this.type === 'datetimerange'; this.picker.selectionMode = this.selectionMode; this.picker.unlinkPanels = this.unlinkPanels; this.picker.arrowControl = this.arrowControl || this.timeArrowControl || false; this.$watch('format', function (format) { _this3.picker.format = format; }); var updateOptions = function updateOptions() { var options = _this3.pickerOptions; if (options && options.selectableRange) { var ranges = options.selectableRange; var parser = TYPE_VALUE_RESOLVER_MAP.datetimerange.parser; var format = DEFAULT_FORMATS.timerange; ranges = Array.isArray(ranges) ? ranges : [ranges]; _this3.picker.selectableRange = ranges.map(function (range) { return parser(range, format, _this3.rangeSeparator); }); } for (var option in options) { if (options.hasOwnProperty(option) && // 忽略 time-picker 的该配置项 option !== 'selectableRange') { _this3.picker[option] = options[option]; } } // main format must prevail over undocumented pickerOptions.format if (_this3.format) { _this3.picker.format = _this3.format; } }; updateOptions(); this.unwatchPickerOptions = this.$watch('pickerOptions', function () { return updateOptions(); }, { deep: true }); this.$el.appendChild(this.picker.$el); this.picker.resetView && this.picker.resetView(); this.picker.$on('dodestroy', this.doDestroy); this.picker.$on('pick', function () { var date = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; var visible = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; _this3.userInput = null; _this3.pickerVisible = _this3.picker.visible = visible; _this3.emitInput(date); _this3.picker.resetView && _this3.picker.resetView(); }); this.picker.$on('select-range', function (start, end, pos) { if (_this3.refInput.length === 0) return; if (!pos || pos === 'min') { _this3.refInput[0].setSelectionRange(start, end); _this3.refInput[0].focus(); } else if (pos === 'max') { _this3.refInput[1].setSelectionRange(start, end); _this3.refInput[1].focus(); } }); }, unmountPicker: function unmountPicker() { if (this.picker) { this.picker.$destroy(); this.picker.$off(); if (typeof this.unwatchPickerOptions === 'function') { this.unwatchPickerOptions(); } this.picker.$el.parentNode.removeChild(this.picker.$el); } }, emitChange: function emitChange(val) { // determine user real change only if (!valueEquals(val, this.valueOnOpen)) { this.$emit('change', val); this.valueOnOpen = val; if (this.validateEvent) { this.dispatch('ElFormItem', 'el.form.change', val); } } }, emitInput: function emitInput(val) { var formatted = this.formatToValue(val); if (!valueEquals(this.value, formatted)) { this.$emit('input', formatted); } }, isValidValue: function isValidValue(value) { if (!this.picker) { this.mountPicker(); } if (this.picker.isValidValue) { return value && this.picker.isValidValue(value); } else { return true; } } } }); // CONCATENATED MODULE: ./packages/date-picker/src/picker.vue?vue&type=script&lang=js& /* harmony default export */ var src_pickervue_type_script_lang_js_ = (pickervue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/picker.vue /* normalize component */ var picker_component = normalizeComponent( src_pickervue_type_script_lang_js_, pickervue_type_template_id_79ae069f_render, pickervue_type_template_id_79ae069f_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var picker_api; } picker_component.options.__file = "packages/date-picker/src/picker.vue" /* harmony default export */ var picker = (picker_component.exports); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date.vue?vue&type=template&id=2440d4ea& var datevue_type_template_id_2440d4ea_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "after-enter": _vm.handleEnter, "after-leave": _vm.handleLeave } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-picker-panel el-date-picker el-popper", class: [ { "has-sidebar": _vm.$slots.sidebar || _vm.shortcuts, "has-time": _vm.showTime }, _vm.popperClass ] }, [ _c( "div", { staticClass: "el-picker-panel__body-wrapper" }, [ _vm._t("sidebar"), _vm.shortcuts ? _c( "div", { staticClass: "el-picker-panel__sidebar" }, _vm._l(_vm.shortcuts, function(shortcut, key) { return _c( "button", { key: key, staticClass: "el-picker-panel__shortcut", attrs: { type: "button" }, on: { click: function($event) { _vm.handleShortcutClick(shortcut) } } }, [_vm._v(_vm._s(shortcut.text))] ) }), 0 ) : _vm._e(), _c("div", { staticClass: "el-picker-panel__body" }, [ _vm.showTime ? _c("div", { staticClass: "el-date-picker__time-header" }, [ _c( "span", { staticClass: "el-date-picker__editor-wrap" }, [ _c("el-input", { attrs: { placeholder: _vm.t("el.datepicker.selectDate"), value: _vm.visibleDate, size: "small" }, on: { input: function(val) { return (_vm.userInputDate = val) }, change: _vm.handleVisibleDateChange } }) ], 1 ), _c( "span", { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: _vm.handleTimePickClose, expression: "handleTimePickClose" } ], staticClass: "el-date-picker__editor-wrap" }, [ _c("el-input", { ref: "input", attrs: { placeholder: _vm.t("el.datepicker.selectTime"), value: _vm.visibleTime, size: "small" }, on: { focus: function($event) { _vm.timePickerVisible = true }, input: function(val) { return (_vm.userInputTime = val) }, change: _vm.handleVisibleTimeChange } }), _c("time-picker", { ref: "timepicker", attrs: { "time-arrow-control": _vm.arrowControl, visible: _vm.timePickerVisible }, on: { pick: _vm.handleTimePick, mounted: _vm.proxyTimePickerDataProperties } }) ], 1 ) ]) : _vm._e(), _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.currentView !== "time", expression: "currentView !== 'time'" } ], staticClass: "el-date-picker__header", class: { "el-date-picker__header--bordered": _vm.currentView === "year" || _vm.currentView === "month" } }, [ _c("button", { staticClass: "el-picker-panel__icon-btn el-date-picker__prev-btn el-icon-d-arrow-left", attrs: { type: "button", "aria-label": _vm.t("el.datepicker.prevYear") }, on: { click: _vm.prevYear } }), _c("button", { directives: [ { name: "show", rawName: "v-show", value: _vm.currentView === "date", expression: "currentView === 'date'" } ], staticClass: "el-picker-panel__icon-btn el-date-picker__prev-btn el-icon-arrow-left", attrs: { type: "button", "aria-label": _vm.t("el.datepicker.prevMonth") }, on: { click: _vm.prevMonth } }), _c( "span", { staticClass: "el-date-picker__header-label", attrs: { role: "button" }, on: { click: _vm.showYearPicker } }, [_vm._v(_vm._s(_vm.yearLabel))] ), _c( "span", { directives: [ { name: "show", rawName: "v-show", value: _vm.currentView === "date", expression: "currentView === 'date'" } ], staticClass: "el-date-picker__header-label", class: { active: _vm.currentView === "month" }, attrs: { role: "button" }, on: { click: _vm.showMonthPicker } }, [ _vm._v( _vm._s(_vm.t("el.datepicker.month" + (_vm.month + 1))) ) ] ), _c("button", { staticClass: "el-picker-panel__icon-btn el-date-picker__next-btn el-icon-d-arrow-right", attrs: { type: "button", "aria-label": _vm.t("el.datepicker.nextYear") }, on: { click: _vm.nextYear } }), _c("button", { directives: [ { name: "show", rawName: "v-show", value: _vm.currentView === "date", expression: "currentView === 'date'" } ], staticClass: "el-picker-panel__icon-btn el-date-picker__next-btn el-icon-arrow-right", attrs: { type: "button", "aria-label": _vm.t("el.datepicker.nextMonth") }, on: { click: _vm.nextMonth } }) ] ), _c( "div", { staticClass: "el-picker-panel__content" }, [ _c("date-table", { directives: [ { name: "show", rawName: "v-show", value: _vm.currentView === "date", expression: "currentView === 'date'" } ], attrs: { "selection-mode": _vm.selectionMode, "first-day-of-week": _vm.firstDayOfWeek, value: _vm.value, "default-value": _vm.defaultValue ? new Date(_vm.defaultValue) : null, date: _vm.date, "cell-class-name": _vm.cellClassName, "disabled-date": _vm.disabledDate }, on: { pick: _vm.handleDatePick } }), _c("year-table", { directives: [ { name: "show", rawName: "v-show", value: _vm.currentView === "year", expression: "currentView === 'year'" } ], attrs: { value: _vm.value, "default-value": _vm.defaultValue ? new Date(_vm.defaultValue) : null, date: _vm.date, "disabled-date": _vm.disabledDate }, on: { pick: _vm.handleYearPick } }), _c("month-table", { directives: [ { name: "show", rawName: "v-show", value: _vm.currentView === "month", expression: "currentView === 'month'" } ], attrs: { value: _vm.value, "default-value": _vm.defaultValue ? new Date(_vm.defaultValue) : null, date: _vm.date, "disabled-date": _vm.disabledDate }, on: { pick: _vm.handleMonthPick } }) ], 1 ) ]) ], 2 ), _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.footerVisible && _vm.currentView === "date", expression: "footerVisible && currentView === 'date'" } ], staticClass: "el-picker-panel__footer" }, [ _c( "el-button", { directives: [ { name: "show", rawName: "v-show", value: _vm.selectionMode !== "dates", expression: "selectionMode !== 'dates'" } ], staticClass: "el-picker-panel__link-btn", attrs: { size: "mini", type: "text" }, on: { click: _vm.changeToNow } }, [ _vm._v( "\n " + _vm._s(_vm.t("el.datepicker.now")) + "\n " ) ] ), _c( "el-button", { staticClass: "el-picker-panel__link-btn", attrs: { plain: "", size: "mini" }, on: { click: _vm.confirm } }, [ _vm._v( "\n " + _vm._s(_vm.t("el.datepicker.confirm")) + "\n " ) ] ) ], 1 ) ] ) ] ) } var datevue_type_template_id_2440d4ea_staticRenderFns = [] datevue_type_template_id_2440d4ea_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/panel/date.vue?vue&type=template&id=2440d4ea& // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time.vue?vue&type=template&id=3d939089& var timevue_type_template_id_3d939089_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": function($event) { _vm.$emit("dodestroy") } } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-time-panel el-popper", class: _vm.popperClass }, [ _c( "div", { staticClass: "el-time-panel__content", class: { "has-seconds": _vm.showSeconds } }, [ _c("time-spinner", { ref: "spinner", attrs: { "arrow-control": _vm.useArrow, "show-seconds": _vm.showSeconds, "am-pm-mode": _vm.amPmMode, date: _vm.date }, on: { change: _vm.handleChange, "select-range": _vm.setSelectionRange } }) ], 1 ), _c("div", { staticClass: "el-time-panel__footer" }, [ _c( "button", { staticClass: "el-time-panel__btn cancel", attrs: { type: "button" }, on: { click: _vm.handleCancel } }, [_vm._v(_vm._s(_vm.t("el.datepicker.cancel")))] ), _c( "button", { staticClass: "el-time-panel__btn", class: { confirm: !_vm.disabled }, attrs: { type: "button" }, on: { click: function($event) { _vm.handleConfirm() } } }, [_vm._v(_vm._s(_vm.t("el.datepicker.confirm")))] ) ]) ] ) ] ) } var timevue_type_template_id_3d939089_staticRenderFns = [] timevue_type_template_id_3d939089_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/panel/time.vue?vue&type=template&id=3d939089& // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/time-spinner.vue?vue&type=template&id=1facadeb& var time_spinnervue_type_template_id_1facadeb_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-time-spinner", class: { "has-seconds": _vm.showSeconds } }, [ !_vm.arrowControl ? [ _c( "el-scrollbar", { ref: "hours", staticClass: "el-time-spinner__wrapper", attrs: { "wrap-style": "max-height: inherit;", "view-class": "el-time-spinner__list", noresize: "", tag: "ul" }, nativeOn: { mouseenter: function($event) { _vm.emitSelectRange("hours") }, mousemove: function($event) { _vm.adjustCurrentSpinner("hours") } } }, _vm._l(_vm.hoursList, function(disabled, hour) { return _c( "li", { key: hour, staticClass: "el-time-spinner__item", class: { active: hour === _vm.hours, disabled: disabled }, on: { click: function($event) { _vm.handleClick("hours", { value: hour, disabled: disabled }) } } }, [ _vm._v( _vm._s( ("0" + (_vm.amPmMode ? hour % 12 || 12 : hour)).slice( -2 ) ) + _vm._s(_vm.amPm(hour)) ) ] ) }), 0 ), _c( "el-scrollbar", { ref: "minutes", staticClass: "el-time-spinner__wrapper", attrs: { "wrap-style": "max-height: inherit;", "view-class": "el-time-spinner__list", noresize: "", tag: "ul" }, nativeOn: { mouseenter: function($event) { _vm.emitSelectRange("minutes") }, mousemove: function($event) { _vm.adjustCurrentSpinner("minutes") } } }, _vm._l(_vm.minutesList, function(enabled, key) { return _c( "li", { key: key, staticClass: "el-time-spinner__item", class: { active: key === _vm.minutes, disabled: !enabled }, on: { click: function($event) { _vm.handleClick("minutes", { value: key, disabled: false }) } } }, [_vm._v(_vm._s(("0" + key).slice(-2)))] ) }), 0 ), _c( "el-scrollbar", { directives: [ { name: "show", rawName: "v-show", value: _vm.showSeconds, expression: "showSeconds" } ], ref: "seconds", staticClass: "el-time-spinner__wrapper", attrs: { "wrap-style": "max-height: inherit;", "view-class": "el-time-spinner__list", noresize: "", tag: "ul" }, nativeOn: { mouseenter: function($event) { _vm.emitSelectRange("seconds") }, mousemove: function($event) { _vm.adjustCurrentSpinner("seconds") } } }, _vm._l(60, function(second, key) { return _c( "li", { key: key, staticClass: "el-time-spinner__item", class: { active: key === _vm.seconds }, on: { click: function($event) { _vm.handleClick("seconds", { value: key, disabled: false }) } } }, [_vm._v(_vm._s(("0" + key).slice(-2)))] ) }), 0 ) ] : _vm._e(), _vm.arrowControl ? [ _c( "div", { staticClass: "el-time-spinner__wrapper is-arrow", on: { mouseenter: function($event) { _vm.emitSelectRange("hours") } } }, [ _c("i", { directives: [ { name: "repeat-click", rawName: "v-repeat-click", value: _vm.decrease, expression: "decrease" } ], staticClass: "el-time-spinner__arrow el-icon-arrow-up" }), _c("i", { directives: [ { name: "repeat-click", rawName: "v-repeat-click", value: _vm.increase, expression: "increase" } ], staticClass: "el-time-spinner__arrow el-icon-arrow-down" }), _c( "ul", { ref: "hours", staticClass: "el-time-spinner__list" }, _vm._l(_vm.arrowHourList, function(hour, key) { return _c( "li", { key: key, staticClass: "el-time-spinner__item", class: { active: hour === _vm.hours, disabled: _vm.hoursList[hour] } }, [ _vm._v( _vm._s( hour === undefined ? "" : ( "0" + (_vm.amPmMode ? hour % 12 || 12 : hour) ).slice(-2) + _vm.amPm(hour) ) ) ] ) }), 0 ) ] ), _c( "div", { staticClass: "el-time-spinner__wrapper is-arrow", on: { mouseenter: function($event) { _vm.emitSelectRange("minutes") } } }, [ _c("i", { directives: [ { name: "repeat-click", rawName: "v-repeat-click", value: _vm.decrease, expression: "decrease" } ], staticClass: "el-time-spinner__arrow el-icon-arrow-up" }), _c("i", { directives: [ { name: "repeat-click", rawName: "v-repeat-click", value: _vm.increase, expression: "increase" } ], staticClass: "el-time-spinner__arrow el-icon-arrow-down" }), _c( "ul", { ref: "minutes", staticClass: "el-time-spinner__list" }, _vm._l(_vm.arrowMinuteList, function(minute, key) { return _c( "li", { key: key, staticClass: "el-time-spinner__item", class: { active: minute === _vm.minutes } }, [ _vm._v( "\n " + _vm._s( minute === undefined ? "" : ("0" + minute).slice(-2) ) + "\n " ) ] ) }), 0 ) ] ), _vm.showSeconds ? _c( "div", { staticClass: "el-time-spinner__wrapper is-arrow", on: { mouseenter: function($event) { _vm.emitSelectRange("seconds") } } }, [ _c("i", { directives: [ { name: "repeat-click", rawName: "v-repeat-click", value: _vm.decrease, expression: "decrease" } ], staticClass: "el-time-spinner__arrow el-icon-arrow-up" }), _c("i", { directives: [ { name: "repeat-click", rawName: "v-repeat-click", value: _vm.increase, expression: "increase" } ], staticClass: "el-time-spinner__arrow el-icon-arrow-down" }), _c( "ul", { ref: "seconds", staticClass: "el-time-spinner__list" }, _vm._l(_vm.arrowSecondList, function(second, key) { return _c( "li", { key: key, staticClass: "el-time-spinner__item", class: { active: second === _vm.seconds } }, [ _vm._v( "\n " + _vm._s( second === undefined ? "" : ("0" + second).slice(-2) ) + "\n " ) ] ) }), 0 ) ] ) : _vm._e() ] : _vm._e() ], 2 ) } var time_spinnervue_type_template_id_1facadeb_staticRenderFns = [] time_spinnervue_type_template_id_1facadeb_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/basic/time-spinner.vue?vue&type=template&id=1facadeb& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/time-spinner.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var time_spinnervue_type_script_lang_js_ = ({ components: { ElScrollbar: scrollbar_default.a }, directives: { repeatClick: repeat_click }, props: { date: {}, defaultValue: {}, // reserved for future use showSeconds: { type: Boolean, default: true }, arrowControl: Boolean, amPmMode: { type: String, default: '' // 'a': am/pm; 'A': AM/PM } }, computed: { hours: function hours() { return this.date.getHours(); }, minutes: function minutes() { return this.date.getMinutes(); }, seconds: function seconds() { return this.date.getSeconds(); }, hoursList: function hoursList() { return Object(date_util_["getRangeHours"])(this.selectableRange); }, minutesList: function minutesList() { return Object(date_util_["getRangeMinutes"])(this.selectableRange, this.hours); }, arrowHourList: function arrowHourList() { var hours = this.hours; return [hours > 0 ? hours - 1 : undefined, hours, hours < 23 ? hours + 1 : undefined]; }, arrowMinuteList: function arrowMinuteList() { var minutes = this.minutes; return [minutes > 0 ? minutes - 1 : undefined, minutes, minutes < 59 ? minutes + 1 : undefined]; }, arrowSecondList: function arrowSecondList() { var seconds = this.seconds; return [seconds > 0 ? seconds - 1 : undefined, seconds, seconds < 59 ? seconds + 1 : undefined]; } }, data: function data() { return { selectableRange: [], currentScrollbar: null }; }, mounted: function mounted() { var _this = this; this.$nextTick(function () { !_this.arrowControl && _this.bindScrollEvent(); }); }, methods: { increase: function increase() { this.scrollDown(1); }, decrease: function decrease() { this.scrollDown(-1); }, modifyDateField: function modifyDateField(type, value) { switch (type) { case 'hours': this.$emit('change', Object(date_util_["modifyTime"])(this.date, value, this.minutes, this.seconds));break; case 'minutes': this.$emit('change', Object(date_util_["modifyTime"])(this.date, this.hours, value, this.seconds));break; case 'seconds': this.$emit('change', Object(date_util_["modifyTime"])(this.date, this.hours, this.minutes, value));break; } }, handleClick: function handleClick(type, _ref) { var value = _ref.value, disabled = _ref.disabled; if (!disabled) { this.modifyDateField(type, value); this.emitSelectRange(type); this.adjustSpinner(type, value); } }, emitSelectRange: function emitSelectRange(type) { if (type === 'hours') { this.$emit('select-range', 0, 2); } else if (type === 'minutes') { this.$emit('select-range', 3, 5); } else if (type === 'seconds') { this.$emit('select-range', 6, 8); } this.currentScrollbar = type; }, bindScrollEvent: function bindScrollEvent() { var _this2 = this; var bindFuntion = function bindFuntion(type) { _this2.$refs[type].wrap.onscroll = function (e) { // TODO: scroll is emitted when set scrollTop programatically // should find better solutions in the future! _this2.handleScroll(type, e); }; }; bindFuntion('hours'); bindFuntion('minutes'); bindFuntion('seconds'); }, handleScroll: function handleScroll(type) { var value = Math.min(Math.round((this.$refs[type].wrap.scrollTop - (this.scrollBarHeight(type) * 0.5 - 10) / this.typeItemHeight(type) + 3) / this.typeItemHeight(type)), type === 'hours' ? 23 : 59); this.modifyDateField(type, value); }, // NOTE: used by datetime / date-range panel // renamed from adjustScrollTop // should try to refactory it adjustSpinners: function adjustSpinners() { this.adjustSpinner('hours', this.hours); this.adjustSpinner('minutes', this.minutes); this.adjustSpinner('seconds', this.seconds); }, adjustCurrentSpinner: function adjustCurrentSpinner(type) { this.adjustSpinner(type, this[type]); }, adjustSpinner: function adjustSpinner(type, value) { if (this.arrowControl) return; var el = this.$refs[type].wrap; if (el) { el.scrollTop = Math.max(0, value * this.typeItemHeight(type)); } }, scrollDown: function scrollDown(step) { var _this3 = this; if (!this.currentScrollbar) { this.emitSelectRange('hours'); } var label = this.currentScrollbar; var hoursList = this.hoursList; var now = this[label]; if (this.currentScrollbar === 'hours') { var total = Math.abs(step); step = step > 0 ? 1 : -1; var length = hoursList.length; while (length-- && total) { now = (now + step + hoursList.length) % hoursList.length; if (hoursList[now]) { continue; } total--; } if (hoursList[now]) return; } else { now = (now + step + 60) % 60; } this.modifyDateField(label, now); this.adjustSpinner(label, now); this.$nextTick(function () { return _this3.emitSelectRange(_this3.currentScrollbar); }); }, amPm: function amPm(hour) { var shouldShowAmPm = this.amPmMode.toLowerCase() === 'a'; if (!shouldShowAmPm) return ''; var isCapital = this.amPmMode === 'A'; var content = hour < 12 ? ' am' : ' pm'; if (isCapital) content = content.toUpperCase(); return content; }, typeItemHeight: function typeItemHeight(type) { return this.$refs[type].$el.querySelector('li').offsetHeight; }, scrollBarHeight: function scrollBarHeight(type) { return this.$refs[type].$el.offsetHeight; } } }); // CONCATENATED MODULE: ./packages/date-picker/src/basic/time-spinner.vue?vue&type=script&lang=js& /* harmony default export */ var basic_time_spinnervue_type_script_lang_js_ = (time_spinnervue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/basic/time-spinner.vue /* normalize component */ var time_spinner_component = normalizeComponent( basic_time_spinnervue_type_script_lang_js_, time_spinnervue_type_template_id_1facadeb_render, time_spinnervue_type_template_id_1facadeb_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var time_spinner_api; } time_spinner_component.options.__file = "packages/date-picker/src/basic/time-spinner.vue" /* harmony default export */ var time_spinner = (time_spinner_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var timevue_type_script_lang_js_ = ({ mixins: [locale_default.a], components: { TimeSpinner: time_spinner }, props: { visible: Boolean, timeArrowControl: Boolean }, watch: { visible: function visible(val) { var _this = this; if (val) { this.oldValue = this.value; this.$nextTick(function () { return _this.$refs.spinner.emitSelectRange('hours'); }); } else { this.needInitAdjust = true; } }, value: function value(newVal) { var _this2 = this; var date = void 0; if (newVal instanceof Date) { date = Object(date_util_["limitTimeRange"])(newVal, this.selectableRange, this.format); } else if (!newVal) { date = this.defaultValue ? new Date(this.defaultValue) : new Date(); } this.date = date; if (this.visible && this.needInitAdjust) { this.$nextTick(function (_) { return _this2.adjustSpinners(); }); this.needInitAdjust = false; } }, selectableRange: function selectableRange(val) { this.$refs.spinner.selectableRange = val; }, defaultValue: function defaultValue(val) { if (!Object(date_util_["isDate"])(this.value)) { this.date = val ? new Date(val) : new Date(); } } }, data: function data() { return { popperClass: '', format: 'HH:mm:ss', value: '', defaultValue: null, date: new Date(), oldValue: new Date(), selectableRange: [], selectionRange: [0, 2], disabled: false, arrowControl: false, needInitAdjust: true }; }, computed: { showSeconds: function showSeconds() { return (this.format || '').indexOf('ss') !== -1; }, useArrow: function useArrow() { return this.arrowControl || this.timeArrowControl || false; }, amPmMode: function amPmMode() { if ((this.format || '').indexOf('A') !== -1) return 'A'; if ((this.format || '').indexOf('a') !== -1) return 'a'; return ''; } }, methods: { handleCancel: function handleCancel() { this.$emit('pick', this.oldValue, false); }, handleChange: function handleChange(date) { // this.visible avoids edge cases, when use scrolls during panel closing animation if (this.visible) { this.date = Object(date_util_["clearMilliseconds"])(date); // if date is out of range, do not emit if (this.isValidValue(this.date)) { this.$emit('pick', this.date, true); } } }, setSelectionRange: function setSelectionRange(start, end) { this.$emit('select-range', start, end); this.selectionRange = [start, end]; }, handleConfirm: function handleConfirm() { var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; var first = arguments[1]; if (first) return; var date = Object(date_util_["clearMilliseconds"])(Object(date_util_["limitTimeRange"])(this.date, this.selectableRange, this.format)); this.$emit('pick', date, visible, first); }, handleKeydown: function handleKeydown(event) { var keyCode = event.keyCode; var mapping = { 38: -1, 40: 1, 37: -1, 39: 1 }; // Left or Right if (keyCode === 37 || keyCode === 39) { var step = mapping[keyCode]; this.changeSelectionRange(step); event.preventDefault(); return; } // Up or Down if (keyCode === 38 || keyCode === 40) { var _step = mapping[keyCode]; this.$refs.spinner.scrollDown(_step); event.preventDefault(); return; } }, isValidValue: function isValidValue(date) { return Object(date_util_["timeWithinRange"])(date, this.selectableRange, this.format); }, adjustSpinners: function adjustSpinners() { return this.$refs.spinner.adjustSpinners(); }, changeSelectionRange: function changeSelectionRange(step) { var list = [0, 3].concat(this.showSeconds ? [6] : []); var mapping = ['hours', 'minutes'].concat(this.showSeconds ? ['seconds'] : []); var index = list.indexOf(this.selectionRange[0]); var next = (index + step + list.length) % list.length; this.$refs.spinner.emitSelectRange(mapping[next]); } }, mounted: function mounted() { var _this3 = this; this.$nextTick(function () { return _this3.handleConfirm(true, true); }); this.$emit('mounted'); } }); // CONCATENATED MODULE: ./packages/date-picker/src/panel/time.vue?vue&type=script&lang=js& /* harmony default export */ var panel_timevue_type_script_lang_js_ = (timevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/panel/time.vue /* normalize component */ var time_component = normalizeComponent( panel_timevue_type_script_lang_js_, timevue_type_template_id_3d939089_render, timevue_type_template_id_3d939089_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var time_api; } time_component.options.__file = "packages/date-picker/src/panel/time.vue" /* harmony default export */ var panel_time = (time_component.exports); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/year-table.vue?vue&type=template&id=c86ab5e0& var year_tablevue_type_template_id_c86ab5e0_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "table", { staticClass: "el-year-table", on: { click: _vm.handleYearTableClick } }, [ _c("tbody", [ _c("tr", [ _c( "td", { staticClass: "available", class: _vm.getCellStyle(_vm.startYear + 0) }, [_c("a", { staticClass: "cell" }, [_vm._v(_vm._s(_vm.startYear))])] ), _c( "td", { staticClass: "available", class: _vm.getCellStyle(_vm.startYear + 1) }, [ _c("a", { staticClass: "cell" }, [ _vm._v(_vm._s(_vm.startYear + 1)) ]) ] ), _c( "td", { staticClass: "available", class: _vm.getCellStyle(_vm.startYear + 2) }, [ _c("a", { staticClass: "cell" }, [ _vm._v(_vm._s(_vm.startYear + 2)) ]) ] ), _c( "td", { staticClass: "available", class: _vm.getCellStyle(_vm.startYear + 3) }, [ _c("a", { staticClass: "cell" }, [ _vm._v(_vm._s(_vm.startYear + 3)) ]) ] ) ]), _c("tr", [ _c( "td", { staticClass: "available", class: _vm.getCellStyle(_vm.startYear + 4) }, [ _c("a", { staticClass: "cell" }, [ _vm._v(_vm._s(_vm.startYear + 4)) ]) ] ), _c( "td", { staticClass: "available", class: _vm.getCellStyle(_vm.startYear + 5) }, [ _c("a", { staticClass: "cell" }, [ _vm._v(_vm._s(_vm.startYear + 5)) ]) ] ), _c( "td", { staticClass: "available", class: _vm.getCellStyle(_vm.startYear + 6) }, [ _c("a", { staticClass: "cell" }, [ _vm._v(_vm._s(_vm.startYear + 6)) ]) ] ), _c( "td", { staticClass: "available", class: _vm.getCellStyle(_vm.startYear + 7) }, [ _c("a", { staticClass: "cell" }, [ _vm._v(_vm._s(_vm.startYear + 7)) ]) ] ) ]), _c("tr", [ _c( "td", { staticClass: "available", class: _vm.getCellStyle(_vm.startYear + 8) }, [ _c("a", { staticClass: "cell" }, [ _vm._v(_vm._s(_vm.startYear + 8)) ]) ] ), _c( "td", { staticClass: "available", class: _vm.getCellStyle(_vm.startYear + 9) }, [ _c("a", { staticClass: "cell" }, [ _vm._v(_vm._s(_vm.startYear + 9)) ]) ] ), _c("td"), _c("td") ]) ]) ] ) } var year_tablevue_type_template_id_c86ab5e0_staticRenderFns = [] year_tablevue_type_template_id_c86ab5e0_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/basic/year-table.vue?vue&type=template&id=c86ab5e0& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/year-table.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var year_tablevue_type_script_lang_js_datesInYear = function datesInYear(year) { var numOfDays = Object(date_util_["getDayCountOfYear"])(year); var firstDay = new Date(year, 0, 1); return Object(date_util_["range"])(numOfDays).map(function (n) { return Object(date_util_["nextDate"])(firstDay, n); }); }; /* harmony default export */ var year_tablevue_type_script_lang_js_ = ({ props: { disabledDate: {}, value: {}, defaultValue: { validator: function validator(val) { // null or valid Date Object return val === null || val instanceof Date && Object(date_util_["isDate"])(val); } }, date: {} }, computed: { startYear: function startYear() { return Math.floor(this.date.getFullYear() / 10) * 10; } }, methods: { getCellStyle: function getCellStyle(year) { var style = {}; var today = new Date(); style.disabled = typeof this.disabledDate === 'function' ? year_tablevue_type_script_lang_js_datesInYear(year).every(this.disabledDate) : false; style.current = Object(util_["arrayFindIndex"])(Object(util_["coerceTruthyValueToArray"])(this.value), function (date) { return date.getFullYear() === year; }) >= 0; style.today = today.getFullYear() === year; style.default = this.defaultValue && this.defaultValue.getFullYear() === year; return style; }, handleYearTableClick: function handleYearTableClick(event) { var target = event.target; if (target.tagName === 'A') { if (Object(dom_["hasClass"])(target.parentNode, 'disabled')) return; var year = target.textContent || target.innerText; this.$emit('pick', Number(year)); } } } }); // CONCATENATED MODULE: ./packages/date-picker/src/basic/year-table.vue?vue&type=script&lang=js& /* harmony default export */ var basic_year_tablevue_type_script_lang_js_ = (year_tablevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/basic/year-table.vue /* normalize component */ var year_table_component = normalizeComponent( basic_year_tablevue_type_script_lang_js_, year_tablevue_type_template_id_c86ab5e0_render, year_tablevue_type_template_id_c86ab5e0_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var year_table_api; } year_table_component.options.__file = "packages/date-picker/src/basic/year-table.vue" /* harmony default export */ var year_table = (year_table_component.exports); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/month-table.vue?vue&type=template&id=654d4f42& var month_tablevue_type_template_id_654d4f42_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "table", { staticClass: "el-month-table", on: { click: _vm.handleMonthTableClick, mousemove: _vm.handleMouseMove } }, [ _c( "tbody", _vm._l(_vm.rows, function(row, key) { return _c( "tr", { key: key }, _vm._l(row, function(cell, key) { return _c("td", { key: key, class: _vm.getCellStyle(cell) }, [ _c("div", [ _c("a", { staticClass: "cell" }, [ _vm._v( _vm._s( _vm.t("el.datepicker.months." + _vm.months[cell.text]) ) ) ]) ]) ]) }), 0 ) }), 0 ) ] ) } var month_tablevue_type_template_id_654d4f42_staticRenderFns = [] month_tablevue_type_template_id_654d4f42_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/basic/month-table.vue?vue&type=template&id=654d4f42& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/month-table.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // var month_tablevue_type_script_lang_js_datesInMonth = function datesInMonth(year, month) { var numOfDays = Object(date_util_["getDayCountOfMonth"])(year, month); var firstDay = new Date(year, month, 1); return Object(date_util_["range"])(numOfDays).map(function (n) { return Object(date_util_["nextDate"])(firstDay, n); }); }; var clearDate = function clearDate(date) { return new Date(date.getFullYear(), date.getMonth()); }; var getMonthTimestamp = function getMonthTimestamp(time) { if (typeof time === 'number' || typeof time === 'string') { return clearDate(new Date(time)).getTime(); } else if (time instanceof Date) { return clearDate(time).getTime(); } else { return NaN; } }; /* harmony default export */ var month_tablevue_type_script_lang_js_ = ({ props: { disabledDate: {}, value: {}, selectionMode: { default: 'month' }, minDate: {}, maxDate: {}, defaultValue: { validator: function validator(val) { // null or valid Date Object return val === null || Object(date_util_["isDate"])(val) || Array.isArray(val) && val.every(date_util_["isDate"]); } }, date: {}, rangeState: { default: function _default() { return { endDate: null, selecting: false }; } } }, mixins: [locale_default.a], watch: { 'rangeState.endDate': function rangeStateEndDate(newVal) { this.markRange(this.minDate, newVal); }, minDate: function minDate(newVal, oldVal) { if (getMonthTimestamp(newVal) !== getMonthTimestamp(oldVal)) { this.markRange(this.minDate, this.maxDate); } }, maxDate: function maxDate(newVal, oldVal) { if (getMonthTimestamp(newVal) !== getMonthTimestamp(oldVal)) { this.markRange(this.minDate, this.maxDate); } } }, data: function data() { return { months: ['jan', 'feb', 'mar', 'apr', 'may', 'jun', 'jul', 'aug', 'sep', 'oct', 'nov', 'dec'], tableRows: [[], [], []], lastRow: null, lastColumn: null }; }, methods: { cellMatchesDate: function cellMatchesDate(cell, date) { var value = new Date(date); return this.date.getFullYear() === value.getFullYear() && Number(cell.text) === value.getMonth(); }, getCellStyle: function getCellStyle(cell) { var _this = this; var style = {}; var year = this.date.getFullYear(); var today = new Date(); var month = cell.text; var defaultValue = this.defaultValue ? Array.isArray(this.defaultValue) ? this.defaultValue : [this.defaultValue] : []; style.disabled = typeof this.disabledDate === 'function' ? month_tablevue_type_script_lang_js_datesInMonth(year, month).every(this.disabledDate) : false; style.current = Object(util_["arrayFindIndex"])(Object(util_["coerceTruthyValueToArray"])(this.value), function (date) { return date.getFullYear() === year && date.getMonth() === month; }) >= 0; style.today = today.getFullYear() === year && today.getMonth() === month; style.default = defaultValue.some(function (date) { return _this.cellMatchesDate(cell, date); }); if (cell.inRange) { style['in-range'] = true; if (cell.start) { style['start-date'] = true; } if (cell.end) { style['end-date'] = true; } } return style; }, getMonthOfCell: function getMonthOfCell(month) { var year = this.date.getFullYear(); return new Date(year, month, 1); }, markRange: function markRange(minDate, maxDate) { minDate = getMonthTimestamp(minDate); maxDate = getMonthTimestamp(maxDate) || minDate; var _ref = [Math.min(minDate, maxDate), Math.max(minDate, maxDate)]; minDate = _ref[0]; maxDate = _ref[1]; var rows = this.rows; for (var i = 0, k = rows.length; i < k; i++) { var row = rows[i]; for (var j = 0, l = row.length; j < l; j++) { var cell = row[j]; var index = i * 4 + j; var time = new Date(this.date.getFullYear(), index).getTime(); cell.inRange = minDate && time >= minDate && time <= maxDate; cell.start = minDate && time === minDate; cell.end = maxDate && time === maxDate; } } }, handleMouseMove: function handleMouseMove(event) { if (!this.rangeState.selecting) return; var target = event.target; if (target.tagName === 'A') { target = target.parentNode.parentNode; } if (target.tagName === 'DIV') { target = target.parentNode; } if (target.tagName !== 'TD') return; var row = target.parentNode.rowIndex; var column = target.cellIndex; // can not select disabled date if (this.rows[row][column].disabled) return; // only update rangeState when mouse moves to a new cell // this avoids frequent Date object creation and improves performance if (row !== this.lastRow || column !== this.lastColumn) { this.lastRow = row; this.lastColumn = column; this.$emit('changerange', { minDate: this.minDate, maxDate: this.maxDate, rangeState: { selecting: true, endDate: this.getMonthOfCell(row * 4 + column) } }); } }, handleMonthTableClick: function handleMonthTableClick(event) { var target = event.target; if (target.tagName === 'A') { target = target.parentNode.parentNode; } if (target.tagName === 'DIV') { target = target.parentNode; } if (target.tagName !== 'TD') return; if (Object(dom_["hasClass"])(target, 'disabled')) return; var column = target.cellIndex; var row = target.parentNode.rowIndex; var month = row * 4 + column; var newDate = this.getMonthOfCell(month); if (this.selectionMode === 'range') { if (!this.rangeState.selecting) { this.$emit('pick', { minDate: newDate, maxDate: null }); this.rangeState.selecting = true; } else { if (newDate >= this.minDate) { this.$emit('pick', { minDate: this.minDate, maxDate: newDate }); } else { this.$emit('pick', { minDate: newDate, maxDate: this.minDate }); } this.rangeState.selecting = false; } } else { this.$emit('pick', month); } } }, computed: { rows: function rows() { var _this2 = this; // TODO: refactory rows / getCellClasses var rows = this.tableRows; var disabledDate = this.disabledDate; var selectedDate = []; var now = getMonthTimestamp(new Date()); for (var i = 0; i < 3; i++) { var row = rows[i]; var _loop = function _loop(j) { var cell = row[j]; if (!cell) { cell = { row: i, column: j, type: 'normal', inRange: false, start: false, end: false }; } cell.type = 'normal'; var index = i * 4 + j; var time = new Date(_this2.date.getFullYear(), index).getTime(); cell.inRange = time >= getMonthTimestamp(_this2.minDate) && time <= getMonthTimestamp(_this2.maxDate); cell.start = _this2.minDate && time === getMonthTimestamp(_this2.minDate); cell.end = _this2.maxDate && time === getMonthTimestamp(_this2.maxDate); var isToday = time === now; if (isToday) { cell.type = 'today'; } cell.text = index; var cellDate = new Date(time); cell.disabled = typeof disabledDate === 'function' && disabledDate(cellDate); cell.selected = Object(util_["arrayFind"])(selectedDate, function (date) { return date.getTime() === cellDate.getTime(); }); _this2.$set(row, j, cell); }; for (var j = 0; j < 4; j++) { _loop(j); } } return rows; } } }); // CONCATENATED MODULE: ./packages/date-picker/src/basic/month-table.vue?vue&type=script&lang=js& /* harmony default export */ var basic_month_tablevue_type_script_lang_js_ = (month_tablevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/basic/month-table.vue /* normalize component */ var month_table_component = normalizeComponent( basic_month_tablevue_type_script_lang_js_, month_tablevue_type_template_id_654d4f42_render, month_tablevue_type_template_id_654d4f42_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var month_table_api; } month_table_component.options.__file = "packages/date-picker/src/basic/month-table.vue" /* harmony default export */ var month_table = (month_table_component.exports); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/date-table.vue?vue&type=template&id=5d1f3341& var date_tablevue_type_template_id_5d1f3341_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "table", { staticClass: "el-date-table", class: { "is-week-mode": _vm.selectionMode === "week" }, attrs: { cellspacing: "0", cellpadding: "0" }, on: { click: _vm.handleClick, mousemove: _vm.handleMouseMove } }, [ _c( "tbody", [ _c( "tr", [ _vm.showWeekNumber ? _c("th", [_vm._v(_vm._s(_vm.t("el.datepicker.week")))]) : _vm._e(), _vm._l(_vm.WEEKS, function(week, key) { return _c("th", { key: key }, [ _vm._v(_vm._s(_vm.t("el.datepicker.weeks." + week))) ]) }) ], 2 ), _vm._l(_vm.rows, function(row, key) { return _c( "tr", { key: key, staticClass: "el-date-table__row", class: { current: _vm.isWeekActive(row[1]) } }, _vm._l(row, function(cell, key) { return _c("td", { key: key, class: _vm.getCellClasses(cell) }, [ _c("div", [ _c("span", [ _vm._v("\n " + _vm._s(cell.text) + "\n ") ]) ]) ]) }), 0 ) }) ], 2 ) ] ) } var date_tablevue_type_template_id_5d1f3341_staticRenderFns = [] date_tablevue_type_template_id_5d1f3341_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/basic/date-table.vue?vue&type=template&id=5d1f3341& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/basic/date-table.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var _WEEKS = ['sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat']; var date_tablevue_type_script_lang_js_getDateTimestamp = function getDateTimestamp(time) { if (typeof time === 'number' || typeof time === 'string') { return Object(date_util_["clearTime"])(new Date(time)).getTime(); } else if (time instanceof Date) { return Object(date_util_["clearTime"])(time).getTime(); } else { return NaN; } }; // remove the first element that satisfies `pred` from arr // return a new array if modification occurs // return the original array otherwise var date_tablevue_type_script_lang_js_removeFromArray = function removeFromArray(arr, pred) { var idx = typeof pred === 'function' ? Object(util_["arrayFindIndex"])(arr, pred) : arr.indexOf(pred); return idx >= 0 ? [].concat(arr.slice(0, idx), arr.slice(idx + 1)) : arr; }; /* harmony default export */ var date_tablevue_type_script_lang_js_ = ({ mixins: [locale_default.a], props: { firstDayOfWeek: { default: 7, type: Number, validator: function validator(val) { return val >= 1 && val <= 7; } }, value: {}, defaultValue: { validator: function validator(val) { // either: null, valid Date object, Array of valid Date objects return val === null || Object(date_util_["isDate"])(val) || Array.isArray(val) && val.every(date_util_["isDate"]); } }, date: {}, selectionMode: { default: 'day' }, showWeekNumber: { type: Boolean, default: false }, disabledDate: {}, cellClassName: {}, minDate: {}, maxDate: {}, rangeState: { default: function _default() { return { endDate: null, selecting: false }; } } }, computed: { offsetDay: function offsetDay() { var week = this.firstDayOfWeek; // 周日为界限,左右偏移的天数,3217654 例如周一就是 -1,目的是调整前两行日期的位置 return week > 3 ? 7 - week : -week; }, WEEKS: function WEEKS() { var week = this.firstDayOfWeek; return _WEEKS.concat(_WEEKS).slice(week, week + 7); }, year: function year() { return this.date.getFullYear(); }, month: function month() { return this.date.getMonth(); }, startDate: function startDate() { return Object(date_util_["getStartDateOfMonth"])(this.year, this.month); }, rows: function rows() { var _this = this; // TODO: refactory rows / getCellClasses var date = new Date(this.year, this.month, 1); var day = Object(date_util_["getFirstDayOfMonth"])(date); // day of first day var dateCountOfMonth = Object(date_util_["getDayCountOfMonth"])(date.getFullYear(), date.getMonth()); var dateCountOfLastMonth = Object(date_util_["getDayCountOfMonth"])(date.getFullYear(), date.getMonth() === 0 ? 11 : date.getMonth() - 1); day = day === 0 ? 7 : day; var offset = this.offsetDay; var rows = this.tableRows; var count = 1; var startDate = this.startDate; var disabledDate = this.disabledDate; var cellClassName = this.cellClassName; var selectedDate = this.selectionMode === 'dates' ? Object(util_["coerceTruthyValueToArray"])(this.value) : []; var now = date_tablevue_type_script_lang_js_getDateTimestamp(new Date()); for (var i = 0; i < 6; i++) { var row = rows[i]; if (this.showWeekNumber) { if (!row[0]) { row[0] = { type: 'week', text: Object(date_util_["getWeekNumber"])(Object(date_util_["nextDate"])(startDate, i * 7 + 1)) }; } } var _loop = function _loop(j) { var cell = row[_this.showWeekNumber ? j + 1 : j]; if (!cell) { cell = { row: i, column: j, type: 'normal', inRange: false, start: false, end: false }; } cell.type = 'normal'; var index = i * 7 + j; var time = Object(date_util_["nextDate"])(startDate, index - offset).getTime(); cell.inRange = time >= date_tablevue_type_script_lang_js_getDateTimestamp(_this.minDate) && time <= date_tablevue_type_script_lang_js_getDateTimestamp(_this.maxDate); cell.start = _this.minDate && time === date_tablevue_type_script_lang_js_getDateTimestamp(_this.minDate); cell.end = _this.maxDate && time === date_tablevue_type_script_lang_js_getDateTimestamp(_this.maxDate); var isToday = time === now; if (isToday) { cell.type = 'today'; } if (i >= 0 && i <= 1) { var numberOfDaysFromPreviousMonth = day + offset < 0 ? 7 + day + offset : day + offset; if (j + i * 7 >= numberOfDaysFromPreviousMonth) { cell.text = count++; } else { cell.text = dateCountOfLastMonth - (numberOfDaysFromPreviousMonth - j % 7) + 1 + i * 7; cell.type = 'prev-month'; } } else { if (count <= dateCountOfMonth) { cell.text = count++; } else { cell.text = count++ - dateCountOfMonth; cell.type = 'next-month'; } } var cellDate = new Date(time); cell.disabled = typeof disabledDate === 'function' && disabledDate(cellDate); cell.selected = Object(util_["arrayFind"])(selectedDate, function (date) { return date.getTime() === cellDate.getTime(); }); cell.customClass = typeof cellClassName === 'function' && cellClassName(cellDate); _this.$set(row, _this.showWeekNumber ? j + 1 : j, cell); }; for (var j = 0; j < 7; j++) { _loop(j); } if (this.selectionMode === 'week') { var start = this.showWeekNumber ? 1 : 0; var end = this.showWeekNumber ? 7 : 6; var isWeekActive = this.isWeekActive(row[start + 1]); row[start].inRange = isWeekActive; row[start].start = isWeekActive; row[end].inRange = isWeekActive; row[end].end = isWeekActive; } } return rows; } }, watch: { 'rangeState.endDate': function rangeStateEndDate(newVal) { this.markRange(this.minDate, newVal); }, minDate: function minDate(newVal, oldVal) { if (date_tablevue_type_script_lang_js_getDateTimestamp(newVal) !== date_tablevue_type_script_lang_js_getDateTimestamp(oldVal)) { this.markRange(this.minDate, this.maxDate); } }, maxDate: function maxDate(newVal, oldVal) { if (date_tablevue_type_script_lang_js_getDateTimestamp(newVal) !== date_tablevue_type_script_lang_js_getDateTimestamp(oldVal)) { this.markRange(this.minDate, this.maxDate); } } }, data: function data() { return { tableRows: [[], [], [], [], [], []], lastRow: null, lastColumn: null }; }, methods: { cellMatchesDate: function cellMatchesDate(cell, date) { var value = new Date(date); return this.year === value.getFullYear() && this.month === value.getMonth() && Number(cell.text) === value.getDate(); }, getCellClasses: function getCellClasses(cell) { var _this2 = this; var selectionMode = this.selectionMode; var defaultValue = this.defaultValue ? Array.isArray(this.defaultValue) ? this.defaultValue : [this.defaultValue] : []; var classes = []; if ((cell.type === 'normal' || cell.type === 'today') && !cell.disabled) { classes.push('available'); if (cell.type === 'today') { classes.push('today'); } } else { classes.push(cell.type); } if (cell.type === 'normal' && defaultValue.some(function (date) { return _this2.cellMatchesDate(cell, date); })) { classes.push('default'); } if (selectionMode === 'day' && (cell.type === 'normal' || cell.type === 'today') && this.cellMatchesDate(cell, this.value)) { classes.push('current'); } if (cell.inRange && (cell.type === 'normal' || cell.type === 'today' || this.selectionMode === 'week')) { classes.push('in-range'); if (cell.start) { classes.push('start-date'); } if (cell.end) { classes.push('end-date'); } } if (cell.disabled) { classes.push('disabled'); } if (cell.selected) { classes.push('selected'); } if (cell.customClass) { classes.push(cell.customClass); } return classes.join(' '); }, getDateOfCell: function getDateOfCell(row, column) { var offsetFromStart = row * 7 + (column - (this.showWeekNumber ? 1 : 0)) - this.offsetDay; return Object(date_util_["nextDate"])(this.startDate, offsetFromStart); }, isWeekActive: function isWeekActive(cell) { if (this.selectionMode !== 'week') return false; var newDate = new Date(this.year, this.month, 1); var year = newDate.getFullYear(); var month = newDate.getMonth(); if (cell.type === 'prev-month') { newDate.setMonth(month === 0 ? 11 : month - 1); newDate.setFullYear(month === 0 ? year - 1 : year); } if (cell.type === 'next-month') { newDate.setMonth(month === 11 ? 0 : month + 1); newDate.setFullYear(month === 11 ? year + 1 : year); } newDate.setDate(parseInt(cell.text, 10)); if (Object(date_util_["isDate"])(this.value)) { var dayOffset = (this.value.getDay() - this.firstDayOfWeek + 7) % 7 - 1; var weekDate = Object(date_util_["prevDate"])(this.value, dayOffset); return weekDate.getTime() === newDate.getTime(); } return false; }, markRange: function markRange(minDate, maxDate) { minDate = date_tablevue_type_script_lang_js_getDateTimestamp(minDate); maxDate = date_tablevue_type_script_lang_js_getDateTimestamp(maxDate) || minDate; var _ref = [Math.min(minDate, maxDate), Math.max(minDate, maxDate)]; minDate = _ref[0]; maxDate = _ref[1]; var startDate = this.startDate; var rows = this.rows; for (var i = 0, k = rows.length; i < k; i++) { var row = rows[i]; for (var j = 0, l = row.length; j < l; j++) { if (this.showWeekNumber && j === 0) continue; var _cell = row[j]; var index = i * 7 + j + (this.showWeekNumber ? -1 : 0); var time = Object(date_util_["nextDate"])(startDate, index - this.offsetDay).getTime(); _cell.inRange = minDate && time >= minDate && time <= maxDate; _cell.start = minDate && time === minDate; _cell.end = maxDate && time === maxDate; } } }, handleMouseMove: function handleMouseMove(event) { if (!this.rangeState.selecting) return; var target = event.target; if (target.tagName === 'SPAN') { target = target.parentNode.parentNode; } if (target.tagName === 'DIV') { target = target.parentNode; } if (target.tagName !== 'TD') return; var row = target.parentNode.rowIndex - 1; var column = target.cellIndex; // can not select disabled date if (this.rows[row][column].disabled) return; // only update rangeState when mouse moves to a new cell // this avoids frequent Date object creation and improves performance if (row !== this.lastRow || column !== this.lastColumn) { this.lastRow = row; this.lastColumn = column; this.$emit('changerange', { minDate: this.minDate, maxDate: this.maxDate, rangeState: { selecting: true, endDate: this.getDateOfCell(row, column) } }); } }, handleClick: function handleClick(event) { var target = event.target; if (target.tagName === 'SPAN') { target = target.parentNode.parentNode; } if (target.tagName === 'DIV') { target = target.parentNode; } if (target.tagName !== 'TD') return; var row = target.parentNode.rowIndex - 1; var column = this.selectionMode === 'week' ? 1 : target.cellIndex; var cell = this.rows[row][column]; if (cell.disabled || cell.type === 'week') return; var newDate = this.getDateOfCell(row, column); if (this.selectionMode === 'range') { if (!this.rangeState.selecting) { this.$emit('pick', { minDate: newDate, maxDate: null }); this.rangeState.selecting = true; } else { if (newDate >= this.minDate) { this.$emit('pick', { minDate: this.minDate, maxDate: newDate }); } else { this.$emit('pick', { minDate: newDate, maxDate: this.minDate }); } this.rangeState.selecting = false; } } else if (this.selectionMode === 'day') { this.$emit('pick', newDate); } else if (this.selectionMode === 'week') { var weekNumber = Object(date_util_["getWeekNumber"])(newDate); var value = newDate.getFullYear() + 'w' + weekNumber; this.$emit('pick', { year: newDate.getFullYear(), week: weekNumber, value: value, date: newDate }); } else if (this.selectionMode === 'dates') { var _value = this.value || []; var newValue = cell.selected ? date_tablevue_type_script_lang_js_removeFromArray(_value, function (date) { return date.getTime() === newDate.getTime(); }) : [].concat(_value, [newDate]); this.$emit('pick', newValue); } } } }); // CONCATENATED MODULE: ./packages/date-picker/src/basic/date-table.vue?vue&type=script&lang=js& /* harmony default export */ var basic_date_tablevue_type_script_lang_js_ = (date_tablevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/basic/date-table.vue /* normalize component */ var date_table_component = normalizeComponent( basic_date_tablevue_type_script_lang_js_, date_tablevue_type_template_id_5d1f3341_render, date_tablevue_type_template_id_5d1f3341_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var date_table_api; } date_table_component.options.__file = "packages/date-picker/src/basic/date-table.vue" /* harmony default export */ var date_table = (date_table_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var datevue_type_script_lang_js_ = ({ mixins: [locale_default.a], directives: { Clickoutside: clickoutside_default.a }, watch: { showTime: function showTime(val) { var _this = this; /* istanbul ignore if */ if (!val) return; this.$nextTick(function (_) { var inputElm = _this.$refs.input.$el; if (inputElm) { _this.pickerWidth = inputElm.getBoundingClientRect().width + 10; } }); }, value: function value(val) { if (this.selectionMode === 'dates' && this.value) return; if (Object(date_util_["isDate"])(val)) { this.date = new Date(val); } else { this.date = this.getDefaultValue(); } }, defaultValue: function defaultValue(val) { if (!Object(date_util_["isDate"])(this.value)) { this.date = val ? new Date(val) : new Date(); } }, timePickerVisible: function timePickerVisible(val) { var _this2 = this; if (val) this.$nextTick(function () { return _this2.$refs.timepicker.adjustSpinners(); }); }, selectionMode: function selectionMode(newVal) { if (newVal === 'month') { /* istanbul ignore next */ if (this.currentView !== 'year' || this.currentView !== 'month') { this.currentView = 'month'; } } else if (newVal === 'dates') { this.currentView = 'date'; } } }, methods: { proxyTimePickerDataProperties: function proxyTimePickerDataProperties() { var _this3 = this; var format = function format(timeFormat) { _this3.$refs.timepicker.format = timeFormat; }; var value = function value(_value) { _this3.$refs.timepicker.value = _value; }; var date = function date(_date) { _this3.$refs.timepicker.date = _date; }; var selectableRange = function selectableRange(_selectableRange) { _this3.$refs.timepicker.selectableRange = _selectableRange; }; this.$watch('value', value); this.$watch('date', date); this.$watch('selectableRange', selectableRange); format(this.timeFormat); value(this.value); date(this.date); selectableRange(this.selectableRange); }, handleClear: function handleClear() { this.date = this.getDefaultValue(); this.$emit('pick', null); }, emit: function emit(value) { var _this4 = this; for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { args[_key - 1] = arguments[_key]; } if (!value) { this.$emit.apply(this, ['pick', value].concat(args)); } else if (Array.isArray(value)) { var dates = value.map(function (date) { return _this4.showTime ? Object(date_util_["clearMilliseconds"])(date) : Object(date_util_["clearTime"])(date); }); this.$emit.apply(this, ['pick', dates].concat(args)); } else { this.$emit.apply(this, ['pick', this.showTime ? Object(date_util_["clearMilliseconds"])(value) : Object(date_util_["clearTime"])(value)].concat(args)); } this.userInputDate = null; this.userInputTime = null; }, // resetDate() { // this.date = new Date(this.date); // }, showMonthPicker: function showMonthPicker() { this.currentView = 'month'; }, showYearPicker: function showYearPicker() { this.currentView = 'year'; }, // XXX: 没用到 // handleLabelClick() { // if (this.currentView === 'date') { // this.showMonthPicker(); // } else if (this.currentView === 'month') { // this.showYearPicker(); // } // }, prevMonth: function prevMonth() { this.date = Object(date_util_["prevMonth"])(this.date); }, nextMonth: function nextMonth() { this.date = Object(date_util_["nextMonth"])(this.date); }, prevYear: function prevYear() { if (this.currentView === 'year') { this.date = Object(date_util_["prevYear"])(this.date, 10); } else { this.date = Object(date_util_["prevYear"])(this.date); } }, nextYear: function nextYear() { if (this.currentView === 'year') { this.date = Object(date_util_["nextYear"])(this.date, 10); } else { this.date = Object(date_util_["nextYear"])(this.date); } }, handleShortcutClick: function handleShortcutClick(shortcut) { if (shortcut.onClick) { shortcut.onClick(this); } }, handleTimePick: function handleTimePick(value, visible, first) { if (Object(date_util_["isDate"])(value)) { var newDate = this.value ? Object(date_util_["modifyTime"])(this.value, value.getHours(), value.getMinutes(), value.getSeconds()) : Object(date_util_["modifyWithTimeString"])(this.getDefaultValue(), this.defaultTime); this.date = newDate; this.emit(this.date, true); } else { this.emit(value, true); } if (!first) { this.timePickerVisible = visible; } }, handleTimePickClose: function handleTimePickClose() { this.timePickerVisible = false; }, handleMonthPick: function handleMonthPick(month) { if (this.selectionMode === 'month') { this.date = Object(date_util_["modifyDate"])(this.date, this.year, month, 1); this.emit(this.date); } else { this.date = Object(date_util_["changeYearMonthAndClampDate"])(this.date, this.year, month); // TODO: should emit intermediate value ?? // this.emit(this.date); this.currentView = 'date'; } }, handleDatePick: function handleDatePick(value) { if (this.selectionMode === 'day') { var newDate = this.value ? Object(date_util_["modifyDate"])(this.value, value.getFullYear(), value.getMonth(), value.getDate()) : Object(date_util_["modifyWithTimeString"])(value, this.defaultTime); // change default time while out of selectableRange if (!this.checkDateWithinRange(newDate)) { newDate = Object(date_util_["modifyDate"])(this.selectableRange[0][0], value.getFullYear(), value.getMonth(), value.getDate()); } this.date = newDate; this.emit(this.date, this.showTime); } else if (this.selectionMode === 'week') { this.emit(value.date); } else if (this.selectionMode === 'dates') { this.emit(value, true); // set false to keep panel open } }, handleYearPick: function handleYearPick(year) { if (this.selectionMode === 'year') { this.date = Object(date_util_["modifyDate"])(this.date, year, 0, 1); this.emit(this.date); } else { this.date = Object(date_util_["changeYearMonthAndClampDate"])(this.date, year, this.month); // TODO: should emit intermediate value ?? // this.emit(this.date, true); this.currentView = 'month'; } }, changeToNow: function changeToNow() { // NOTE: not a permanent solution // consider disable "now" button in the future if ((!this.disabledDate || !this.disabledDate(new Date())) && this.checkDateWithinRange(new Date())) { this.date = new Date(); this.emit(this.date); } }, confirm: function confirm() { if (this.selectionMode === 'dates') { this.emit(this.value); } else { // value were emitted in handle{Date,Time}Pick, nothing to update here // deal with the scenario where: user opens the picker, then confirm without doing anything var value = this.value ? this.value : Object(date_util_["modifyWithTimeString"])(this.getDefaultValue(), this.defaultTime); this.date = new Date(value); // refresh date this.emit(value); } }, resetView: function resetView() { if (this.selectionMode === 'month') { this.currentView = 'month'; } else if (this.selectionMode === 'year') { this.currentView = 'year'; } else { this.currentView = 'date'; } }, handleEnter: function handleEnter() { document.body.addEventListener('keydown', this.handleKeydown); }, handleLeave: function handleLeave() { this.$emit('dodestroy'); document.body.removeEventListener('keydown', this.handleKeydown); }, handleKeydown: function handleKeydown(event) { var keyCode = event.keyCode; var list = [38, 40, 37, 39]; if (this.visible && !this.timePickerVisible) { if (list.indexOf(keyCode) !== -1) { this.handleKeyControl(keyCode); event.stopPropagation(); event.preventDefault(); } if (keyCode === 13 && this.userInputDate === null && this.userInputTime === null) { // Enter this.emit(this.date, false); } } }, handleKeyControl: function handleKeyControl(keyCode) { var mapping = { 'year': { 38: -4, 40: 4, 37: -1, 39: 1, offset: function offset(date, step) { return date.setFullYear(date.getFullYear() + step); } }, 'month': { 38: -4, 40: 4, 37: -1, 39: 1, offset: function offset(date, step) { return date.setMonth(date.getMonth() + step); } }, 'week': { 38: -1, 40: 1, 37: -1, 39: 1, offset: function offset(date, step) { return date.setDate(date.getDate() + step * 7); } }, 'day': { 38: -7, 40: 7, 37: -1, 39: 1, offset: function offset(date, step) { return date.setDate(date.getDate() + step); } } }; var mode = this.selectionMode; var year = 3.1536e10; var now = this.date.getTime(); var newDate = new Date(this.date.getTime()); while (Math.abs(now - newDate.getTime()) <= year) { var map = mapping[mode]; map.offset(newDate, map[keyCode]); if (typeof this.disabledDate === 'function' && this.disabledDate(newDate)) { continue; } this.date = newDate; this.$emit('pick', newDate, true); break; } }, handleVisibleTimeChange: function handleVisibleTimeChange(value) { var time = Object(date_util_["parseDate"])(value, this.timeFormat); if (time && this.checkDateWithinRange(time)) { this.date = Object(date_util_["modifyDate"])(time, this.year, this.month, this.monthDate); this.userInputTime = null; this.$refs.timepicker.value = this.date; this.timePickerVisible = false; this.emit(this.date, true); } }, handleVisibleDateChange: function handleVisibleDateChange(value) { var date = Object(date_util_["parseDate"])(value, this.dateFormat); if (date) { if (typeof this.disabledDate === 'function' && this.disabledDate(date)) { return; } this.date = Object(date_util_["modifyTime"])(date, this.date.getHours(), this.date.getMinutes(), this.date.getSeconds()); this.userInputDate = null; this.resetView(); this.emit(this.date, true); } }, isValidValue: function isValidValue(value) { return value && !isNaN(value) && (typeof this.disabledDate === 'function' ? !this.disabledDate(value) : true) && this.checkDateWithinRange(value); }, getDefaultValue: function getDefaultValue() { // if default-value is set, return it // otherwise, return now (the moment this method gets called) return this.defaultValue ? new Date(this.defaultValue) : new Date(); }, checkDateWithinRange: function checkDateWithinRange(date) { return this.selectableRange.length > 0 ? Object(date_util_["timeWithinRange"])(date, this.selectableRange, this.format || 'HH:mm:ss') : true; } }, components: { TimePicker: panel_time, YearTable: year_table, MonthTable: month_table, DateTable: date_table, ElInput: input_default.a, ElButton: button_default.a }, data: function data() { return { popperClass: '', date: new Date(), value: '', defaultValue: null, // use getDefaultValue() for time computation defaultTime: null, showTime: false, selectionMode: 'day', shortcuts: '', visible: false, currentView: 'date', disabledDate: '', cellClassName: '', selectableRange: [], firstDayOfWeek: 7, showWeekNumber: false, timePickerVisible: false, format: '', arrowControl: false, userInputDate: null, userInputTime: null }; }, computed: { year: function year() { return this.date.getFullYear(); }, month: function month() { return this.date.getMonth(); }, week: function week() { return Object(date_util_["getWeekNumber"])(this.date); }, monthDate: function monthDate() { return this.date.getDate(); }, footerVisible: function footerVisible() { return this.showTime || this.selectionMode === 'dates'; }, visibleTime: function visibleTime() { if (this.userInputTime !== null) { return this.userInputTime; } else { return Object(date_util_["formatDate"])(this.value || this.defaultValue, this.timeFormat); } }, visibleDate: function visibleDate() { if (this.userInputDate !== null) { return this.userInputDate; } else { return Object(date_util_["formatDate"])(this.value || this.defaultValue, this.dateFormat); } }, yearLabel: function yearLabel() { var yearTranslation = this.t('el.datepicker.year'); if (this.currentView === 'year') { var startYear = Math.floor(this.year / 10) * 10; if (yearTranslation) { return startYear + ' ' + yearTranslation + ' - ' + (startYear + 9) + ' ' + yearTranslation; } return startYear + ' - ' + (startYear + 9); } return this.year + ' ' + yearTranslation; }, timeFormat: function timeFormat() { if (this.format) { return Object(date_util_["extractTimeFormat"])(this.format); } else { return 'HH:mm:ss'; } }, dateFormat: function dateFormat() { if (this.format) { return Object(date_util_["extractDateFormat"])(this.format); } else { return 'yyyy-MM-dd'; } } } }); // CONCATENATED MODULE: ./packages/date-picker/src/panel/date.vue?vue&type=script&lang=js& /* harmony default export */ var panel_datevue_type_script_lang_js_ = (datevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/panel/date.vue /* normalize component */ var date_component = normalizeComponent( panel_datevue_type_script_lang_js_, datevue_type_template_id_2440d4ea_render, datevue_type_template_id_2440d4ea_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var date_api; } date_component.options.__file = "packages/date-picker/src/panel/date.vue" /* harmony default export */ var panel_date = (date_component.exports); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date-range.vue?vue&type=template&id=2652849a& var date_rangevue_type_template_id_2652849a_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": function($event) { _vm.$emit("dodestroy") } } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-picker-panel el-date-range-picker el-popper", class: [ { "has-sidebar": _vm.$slots.sidebar || _vm.shortcuts, "has-time": _vm.showTime }, _vm.popperClass ] }, [ _c( "div", { staticClass: "el-picker-panel__body-wrapper" }, [ _vm._t("sidebar"), _vm.shortcuts ? _c( "div", { staticClass: "el-picker-panel__sidebar" }, _vm._l(_vm.shortcuts, function(shortcut, key) { return _c( "button", { key: key, staticClass: "el-picker-panel__shortcut", attrs: { type: "button" }, on: { click: function($event) { _vm.handleShortcutClick(shortcut) } } }, [_vm._v(_vm._s(shortcut.text))] ) }), 0 ) : _vm._e(), _c("div", { staticClass: "el-picker-panel__body" }, [ _vm.showTime ? _c( "div", { staticClass: "el-date-range-picker__time-header" }, [ _c( "span", { staticClass: "el-date-range-picker__editors-wrap" }, [ _c( "span", { staticClass: "el-date-range-picker__time-picker-wrap" }, [ _c("el-input", { ref: "minInput", staticClass: "el-date-range-picker__editor", attrs: { size: "small", disabled: _vm.rangeState.selecting, placeholder: _vm.t( "el.datepicker.startDate" ), value: _vm.minVisibleDate }, on: { input: function(val) { return _vm.handleDateInput(val, "min") }, change: function(val) { return _vm.handleDateChange(val, "min") } } }) ], 1 ), _c( "span", { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: _vm.handleMinTimeClose, expression: "handleMinTimeClose" } ], staticClass: "el-date-range-picker__time-picker-wrap" }, [ _c("el-input", { staticClass: "el-date-range-picker__editor", attrs: { size: "small", disabled: _vm.rangeState.selecting, placeholder: _vm.t( "el.datepicker.startTime" ), value: _vm.minVisibleTime }, on: { focus: function($event) { _vm.minTimePickerVisible = true }, input: function(val) { return _vm.handleTimeInput(val, "min") }, change: function(val) { return _vm.handleTimeChange(val, "min") } } }), _c("time-picker", { ref: "minTimePicker", attrs: { "time-arrow-control": _vm.arrowControl, visible: _vm.minTimePickerVisible }, on: { pick: _vm.handleMinTimePick, mounted: function($event) { _vm.$refs.minTimePicker.format = _vm.timeFormat } } }) ], 1 ) ] ), _c("span", { staticClass: "el-icon-arrow-right" }), _c( "span", { staticClass: "el-date-range-picker__editors-wrap is-right" }, [ _c( "span", { staticClass: "el-date-range-picker__time-picker-wrap" }, [ _c("el-input", { staticClass: "el-date-range-picker__editor", attrs: { size: "small", disabled: _vm.rangeState.selecting, placeholder: _vm.t("el.datepicker.endDate"), value: _vm.maxVisibleDate, readonly: !_vm.minDate }, on: { input: function(val) { return _vm.handleDateInput(val, "max") }, change: function(val) { return _vm.handleDateChange(val, "max") } } }) ], 1 ), _c( "span", { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: _vm.handleMaxTimeClose, expression: "handleMaxTimeClose" } ], staticClass: "el-date-range-picker__time-picker-wrap" }, [ _c("el-input", { staticClass: "el-date-range-picker__editor", attrs: { size: "small", disabled: _vm.rangeState.selecting, placeholder: _vm.t("el.datepicker.endTime"), value: _vm.maxVisibleTime, readonly: !_vm.minDate }, on: { focus: function($event) { _vm.minDate && (_vm.maxTimePickerVisible = true) }, input: function(val) { return _vm.handleTimeInput(val, "max") }, change: function(val) { return _vm.handleTimeChange(val, "max") } } }), _c("time-picker", { ref: "maxTimePicker", attrs: { "time-arrow-control": _vm.arrowControl, visible: _vm.maxTimePickerVisible }, on: { pick: _vm.handleMaxTimePick, mounted: function($event) { _vm.$refs.maxTimePicker.format = _vm.timeFormat } } }) ], 1 ) ] ) ] ) : _vm._e(), _c( "div", { staticClass: "el-picker-panel__content el-date-range-picker__content is-left" }, [ _c("div", { staticClass: "el-date-range-picker__header" }, [ _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-d-arrow-left", attrs: { type: "button" }, on: { click: _vm.leftPrevYear } }), _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-arrow-left", attrs: { type: "button" }, on: { click: _vm.leftPrevMonth } }), _vm.unlinkPanels ? _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-d-arrow-right", class: { "is-disabled": !_vm.enableYearArrow }, attrs: { type: "button", disabled: !_vm.enableYearArrow }, on: { click: _vm.leftNextYear } }) : _vm._e(), _vm.unlinkPanels ? _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-arrow-right", class: { "is-disabled": !_vm.enableMonthArrow }, attrs: { type: "button", disabled: !_vm.enableMonthArrow }, on: { click: _vm.leftNextMonth } }) : _vm._e(), _c("div", [_vm._v(_vm._s(_vm.leftLabel))]) ]), _c("date-table", { attrs: { "selection-mode": "range", date: _vm.leftDate, "default-value": _vm.defaultValue, "min-date": _vm.minDate, "max-date": _vm.maxDate, "range-state": _vm.rangeState, "disabled-date": _vm.disabledDate, "cell-class-name": _vm.cellClassName, "first-day-of-week": _vm.firstDayOfWeek }, on: { changerange: _vm.handleChangeRange, pick: _vm.handleRangePick } }) ], 1 ), _c( "div", { staticClass: "el-picker-panel__content el-date-range-picker__content is-right" }, [ _c("div", { staticClass: "el-date-range-picker__header" }, [ _vm.unlinkPanels ? _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-d-arrow-left", class: { "is-disabled": !_vm.enableYearArrow }, attrs: { type: "button", disabled: !_vm.enableYearArrow }, on: { click: _vm.rightPrevYear } }) : _vm._e(), _vm.unlinkPanels ? _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-arrow-left", class: { "is-disabled": !_vm.enableMonthArrow }, attrs: { type: "button", disabled: !_vm.enableMonthArrow }, on: { click: _vm.rightPrevMonth } }) : _vm._e(), _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-d-arrow-right", attrs: { type: "button" }, on: { click: _vm.rightNextYear } }), _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-arrow-right", attrs: { type: "button" }, on: { click: _vm.rightNextMonth } }), _c("div", [_vm._v(_vm._s(_vm.rightLabel))]) ]), _c("date-table", { attrs: { "selection-mode": "range", date: _vm.rightDate, "default-value": _vm.defaultValue, "min-date": _vm.minDate, "max-date": _vm.maxDate, "range-state": _vm.rangeState, "disabled-date": _vm.disabledDate, "cell-class-name": _vm.cellClassName, "first-day-of-week": _vm.firstDayOfWeek }, on: { changerange: _vm.handleChangeRange, pick: _vm.handleRangePick } }) ], 1 ) ]) ], 2 ), _vm.showTime ? _c( "div", { staticClass: "el-picker-panel__footer" }, [ _c( "el-button", { staticClass: "el-picker-panel__link-btn", attrs: { size: "mini", type: "text" }, on: { click: _vm.handleClear } }, [ _vm._v( "\n " + _vm._s(_vm.t("el.datepicker.clear")) + "\n " ) ] ), _c( "el-button", { staticClass: "el-picker-panel__link-btn", attrs: { plain: "", size: "mini", disabled: _vm.btnDisabled }, on: { click: function($event) { _vm.handleConfirm(false) } } }, [ _vm._v( "\n " + _vm._s(_vm.t("el.datepicker.confirm")) + "\n " ) ] ) ], 1 ) : _vm._e() ] ) ] ) } var date_rangevue_type_template_id_2652849a_staticRenderFns = [] date_rangevue_type_template_id_2652849a_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/panel/date-range.vue?vue&type=template&id=2652849a& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/date-range.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var date_rangevue_type_script_lang_js_calcDefaultValue = function calcDefaultValue(defaultValue) { if (Array.isArray(defaultValue)) { return [new Date(defaultValue[0]), new Date(defaultValue[1])]; } else if (defaultValue) { return [new Date(defaultValue), Object(date_util_["nextDate"])(new Date(defaultValue), 1)]; } else { return [new Date(), Object(date_util_["nextDate"])(new Date(), 1)]; } }; /* harmony default export */ var date_rangevue_type_script_lang_js_ = ({ mixins: [locale_default.a], directives: { Clickoutside: clickoutside_default.a }, computed: { btnDisabled: function btnDisabled() { return !(this.minDate && this.maxDate && !this.selecting && this.isValidValue([this.minDate, this.maxDate])); }, leftLabel: function leftLabel() { return this.leftDate.getFullYear() + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + (this.leftDate.getMonth() + 1)); }, rightLabel: function rightLabel() { return this.rightDate.getFullYear() + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + (this.rightDate.getMonth() + 1)); }, leftYear: function leftYear() { return this.leftDate.getFullYear(); }, leftMonth: function leftMonth() { return this.leftDate.getMonth(); }, leftMonthDate: function leftMonthDate() { return this.leftDate.getDate(); }, rightYear: function rightYear() { return this.rightDate.getFullYear(); }, rightMonth: function rightMonth() { return this.rightDate.getMonth(); }, rightMonthDate: function rightMonthDate() { return this.rightDate.getDate(); }, minVisibleDate: function minVisibleDate() { if (this.dateUserInput.min !== null) return this.dateUserInput.min; if (this.minDate) return Object(date_util_["formatDate"])(this.minDate, this.dateFormat); return ''; }, maxVisibleDate: function maxVisibleDate() { if (this.dateUserInput.max !== null) return this.dateUserInput.max; if (this.maxDate || this.minDate) return Object(date_util_["formatDate"])(this.maxDate || this.minDate, this.dateFormat); return ''; }, minVisibleTime: function minVisibleTime() { if (this.timeUserInput.min !== null) return this.timeUserInput.min; if (this.minDate) return Object(date_util_["formatDate"])(this.minDate, this.timeFormat); return ''; }, maxVisibleTime: function maxVisibleTime() { if (this.timeUserInput.max !== null) return this.timeUserInput.max; if (this.maxDate || this.minDate) return Object(date_util_["formatDate"])(this.maxDate || this.minDate, this.timeFormat); return ''; }, timeFormat: function timeFormat() { if (this.format) { return Object(date_util_["extractTimeFormat"])(this.format); } else { return 'HH:mm:ss'; } }, dateFormat: function dateFormat() { if (this.format) { return Object(date_util_["extractDateFormat"])(this.format); } else { return 'yyyy-MM-dd'; } }, enableMonthArrow: function enableMonthArrow() { var nextMonth = (this.leftMonth + 1) % 12; var yearOffset = this.leftMonth + 1 >= 12 ? 1 : 0; return this.unlinkPanels && new Date(this.leftYear + yearOffset, nextMonth) < new Date(this.rightYear, this.rightMonth); }, enableYearArrow: function enableYearArrow() { return this.unlinkPanels && this.rightYear * 12 + this.rightMonth - (this.leftYear * 12 + this.leftMonth + 1) >= 12; } }, data: function data() { return { popperClass: '', value: [], defaultValue: null, defaultTime: null, minDate: '', maxDate: '', leftDate: new Date(), rightDate: Object(date_util_["nextMonth"])(new Date()), rangeState: { endDate: null, selecting: false, row: null, column: null }, showTime: false, shortcuts: '', visible: '', disabledDate: '', cellClassName: '', firstDayOfWeek: 7, minTimePickerVisible: false, maxTimePickerVisible: false, format: '', arrowControl: false, unlinkPanels: false, dateUserInput: { min: null, max: null }, timeUserInput: { min: null, max: null } }; }, watch: { minDate: function minDate(val) { var _this = this; this.dateUserInput.min = null; this.timeUserInput.min = null; this.$nextTick(function () { if (_this.$refs.maxTimePicker && _this.maxDate && _this.maxDate < _this.minDate) { var format = 'HH:mm:ss'; _this.$refs.maxTimePicker.selectableRange = [[Object(date_util_["parseDate"])(Object(date_util_["formatDate"])(_this.minDate, format), format), Object(date_util_["parseDate"])('23:59:59', format)]]; } }); if (val && this.$refs.minTimePicker) { this.$refs.minTimePicker.date = val; this.$refs.minTimePicker.value = val; } }, maxDate: function maxDate(val) { this.dateUserInput.max = null; this.timeUserInput.max = null; if (val && this.$refs.maxTimePicker) { this.$refs.maxTimePicker.date = val; this.$refs.maxTimePicker.value = val; } }, minTimePickerVisible: function minTimePickerVisible(val) { var _this2 = this; if (val) { this.$nextTick(function () { _this2.$refs.minTimePicker.date = _this2.minDate; _this2.$refs.minTimePicker.value = _this2.minDate; _this2.$refs.minTimePicker.adjustSpinners(); }); } }, maxTimePickerVisible: function maxTimePickerVisible(val) { var _this3 = this; if (val) { this.$nextTick(function () { _this3.$refs.maxTimePicker.date = _this3.maxDate; _this3.$refs.maxTimePicker.value = _this3.maxDate; _this3.$refs.maxTimePicker.adjustSpinners(); }); } }, value: function value(newVal) { if (!newVal) { this.minDate = null; this.maxDate = null; } else if (Array.isArray(newVal)) { this.minDate = Object(date_util_["isDate"])(newVal[0]) ? new Date(newVal[0]) : null; this.maxDate = Object(date_util_["isDate"])(newVal[1]) ? new Date(newVal[1]) : null; if (this.minDate) { this.leftDate = this.minDate; if (this.unlinkPanels && this.maxDate) { var minDateYear = this.minDate.getFullYear(); var minDateMonth = this.minDate.getMonth(); var maxDateYear = this.maxDate.getFullYear(); var maxDateMonth = this.maxDate.getMonth(); this.rightDate = minDateYear === maxDateYear && minDateMonth === maxDateMonth ? Object(date_util_["nextMonth"])(this.maxDate) : this.maxDate; } else { this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); } } else { this.leftDate = date_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0]; this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); } } }, defaultValue: function defaultValue(val) { if (!Array.isArray(this.value)) { var _calcDefaultValue = date_rangevue_type_script_lang_js_calcDefaultValue(val), left = _calcDefaultValue[0], right = _calcDefaultValue[1]; this.leftDate = left; this.rightDate = val && val[1] && this.unlinkPanels ? right : Object(date_util_["nextMonth"])(this.leftDate); } } }, methods: { handleClear: function handleClear() { this.minDate = null; this.maxDate = null; this.leftDate = date_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0]; this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); this.$emit('pick', null); }, handleChangeRange: function handleChangeRange(val) { this.minDate = val.minDate; this.maxDate = val.maxDate; this.rangeState = val.rangeState; }, handleDateInput: function handleDateInput(value, type) { this.dateUserInput[type] = value; if (value.length !== this.dateFormat.length) return; var parsedValue = Object(date_util_["parseDate"])(value, this.dateFormat); if (parsedValue) { if (typeof this.disabledDate === 'function' && this.disabledDate(new Date(parsedValue))) { return; } if (type === 'min') { this.minDate = Object(date_util_["modifyDate"])(this.minDate || new Date(), parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate()); this.leftDate = new Date(parsedValue); if (!this.unlinkPanels) { this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); } } else { this.maxDate = Object(date_util_["modifyDate"])(this.maxDate || new Date(), parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate()); this.rightDate = new Date(parsedValue); if (!this.unlinkPanels) { this.leftDate = Object(date_util_["prevMonth"])(parsedValue); } } } }, handleDateChange: function handleDateChange(value, type) { var parsedValue = Object(date_util_["parseDate"])(value, this.dateFormat); if (parsedValue) { if (type === 'min') { this.minDate = Object(date_util_["modifyDate"])(this.minDate, parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate()); if (this.minDate > this.maxDate) { this.maxDate = this.minDate; } } else { this.maxDate = Object(date_util_["modifyDate"])(this.maxDate, parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate()); if (this.maxDate < this.minDate) { this.minDate = this.maxDate; } } } }, handleTimeInput: function handleTimeInput(value, type) { var _this4 = this; this.timeUserInput[type] = value; if (value.length !== this.timeFormat.length) return; var parsedValue = Object(date_util_["parseDate"])(value, this.timeFormat); if (parsedValue) { if (type === 'min') { this.minDate = Object(date_util_["modifyTime"])(this.minDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds()); this.$nextTick(function (_) { return _this4.$refs.minTimePicker.adjustSpinners(); }); } else { this.maxDate = Object(date_util_["modifyTime"])(this.maxDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds()); this.$nextTick(function (_) { return _this4.$refs.maxTimePicker.adjustSpinners(); }); } } }, handleTimeChange: function handleTimeChange(value, type) { var parsedValue = Object(date_util_["parseDate"])(value, this.timeFormat); if (parsedValue) { if (type === 'min') { this.minDate = Object(date_util_["modifyTime"])(this.minDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds()); if (this.minDate > this.maxDate) { this.maxDate = this.minDate; } this.$refs.minTimePicker.value = this.minDate; this.minTimePickerVisible = false; } else { this.maxDate = Object(date_util_["modifyTime"])(this.maxDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds()); if (this.maxDate < this.minDate) { this.minDate = this.maxDate; } this.$refs.maxTimePicker.value = this.minDate; this.maxTimePickerVisible = false; } } }, handleRangePick: function handleRangePick(val) { var _this5 = this; var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; var defaultTime = this.defaultTime || []; var minDate = Object(date_util_["modifyWithTimeString"])(val.minDate, defaultTime[0]); var maxDate = Object(date_util_["modifyWithTimeString"])(val.maxDate, defaultTime[1]); if (this.maxDate === maxDate && this.minDate === minDate) { return; } this.onPick && this.onPick(val); this.maxDate = maxDate; this.minDate = minDate; // workaround for https://github.com/ElemeFE/element/issues/7539, should remove this block when we don't have to care about Chromium 55 - 57 setTimeout(function () { _this5.maxDate = maxDate; _this5.minDate = minDate; }, 10); if (!close || this.showTime) return; this.handleConfirm(); }, handleShortcutClick: function handleShortcutClick(shortcut) { if (shortcut.onClick) { shortcut.onClick(this); } }, handleMinTimePick: function handleMinTimePick(value, visible, first) { this.minDate = this.minDate || new Date(); if (value) { this.minDate = Object(date_util_["modifyTime"])(this.minDate, value.getHours(), value.getMinutes(), value.getSeconds()); } if (!first) { this.minTimePickerVisible = visible; } if (!this.maxDate || this.maxDate && this.maxDate.getTime() < this.minDate.getTime()) { this.maxDate = new Date(this.minDate); } }, handleMinTimeClose: function handleMinTimeClose() { this.minTimePickerVisible = false; }, handleMaxTimePick: function handleMaxTimePick(value, visible, first) { if (this.maxDate && value) { this.maxDate = Object(date_util_["modifyTime"])(this.maxDate, value.getHours(), value.getMinutes(), value.getSeconds()); } if (!first) { this.maxTimePickerVisible = visible; } if (this.maxDate && this.minDate && this.minDate.getTime() > this.maxDate.getTime()) { this.minDate = new Date(this.maxDate); } }, handleMaxTimeClose: function handleMaxTimeClose() { this.maxTimePickerVisible = false; }, // leftPrev*, rightNext* need to take care of `unlinkPanels` leftPrevYear: function leftPrevYear() { this.leftDate = Object(date_util_["prevYear"])(this.leftDate); if (!this.unlinkPanels) { this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); } }, leftPrevMonth: function leftPrevMonth() { this.leftDate = Object(date_util_["prevMonth"])(this.leftDate); if (!this.unlinkPanels) { this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); } }, rightNextYear: function rightNextYear() { if (!this.unlinkPanels) { this.leftDate = Object(date_util_["nextYear"])(this.leftDate); this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); } else { this.rightDate = Object(date_util_["nextYear"])(this.rightDate); } }, rightNextMonth: function rightNextMonth() { if (!this.unlinkPanels) { this.leftDate = Object(date_util_["nextMonth"])(this.leftDate); this.rightDate = Object(date_util_["nextMonth"])(this.leftDate); } else { this.rightDate = Object(date_util_["nextMonth"])(this.rightDate); } }, // leftNext*, rightPrev* are called when `unlinkPanels` is true leftNextYear: function leftNextYear() { this.leftDate = Object(date_util_["nextYear"])(this.leftDate); }, leftNextMonth: function leftNextMonth() { this.leftDate = Object(date_util_["nextMonth"])(this.leftDate); }, rightPrevYear: function rightPrevYear() { this.rightDate = Object(date_util_["prevYear"])(this.rightDate); }, rightPrevMonth: function rightPrevMonth() { this.rightDate = Object(date_util_["prevMonth"])(this.rightDate); }, handleConfirm: function handleConfirm() { var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; if (this.isValidValue([this.minDate, this.maxDate])) { this.$emit('pick', [this.minDate, this.maxDate], visible); } }, isValidValue: function isValidValue(value) { return Array.isArray(value) && value && value[0] && value[1] && Object(date_util_["isDate"])(value[0]) && Object(date_util_["isDate"])(value[1]) && value[0].getTime() <= value[1].getTime() && (typeof this.disabledDate === 'function' ? !this.disabledDate(value[0]) && !this.disabledDate(value[1]) : true); }, resetView: function resetView() { // NOTE: this is a hack to reset {min, max}Date on picker open. // TODO: correct way of doing so is to refactor {min, max}Date to be dependent on value and internal selection state // an alternative would be resetView whenever picker becomes visible, should also investigate date-panel's resetView if (this.minDate && this.maxDate == null) this.rangeState.selecting = false; this.minDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[0]) : null; this.maxDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[1]) : null; } }, components: { TimePicker: panel_time, DateTable: date_table, ElInput: input_default.a, ElButton: button_default.a } }); // CONCATENATED MODULE: ./packages/date-picker/src/panel/date-range.vue?vue&type=script&lang=js& /* harmony default export */ var panel_date_rangevue_type_script_lang_js_ = (date_rangevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/panel/date-range.vue /* normalize component */ var date_range_component = normalizeComponent( panel_date_rangevue_type_script_lang_js_, date_rangevue_type_template_id_2652849a_render, date_rangevue_type_template_id_2652849a_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var date_range_api; } date_range_component.options.__file = "packages/date-picker/src/panel/date-range.vue" /* harmony default export */ var date_range = (date_range_component.exports); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/month-range.vue?vue&type=template&id=f2645fb8& var month_rangevue_type_template_id_f2645fb8_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": function($event) { _vm.$emit("dodestroy") } } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-picker-panel el-date-range-picker el-popper", class: [ { "has-sidebar": _vm.$slots.sidebar || _vm.shortcuts }, _vm.popperClass ] }, [ _c( "div", { staticClass: "el-picker-panel__body-wrapper" }, [ _vm._t("sidebar"), _vm.shortcuts ? _c( "div", { staticClass: "el-picker-panel__sidebar" }, _vm._l(_vm.shortcuts, function(shortcut, key) { return _c( "button", { key: key, staticClass: "el-picker-panel__shortcut", attrs: { type: "button" }, on: { click: function($event) { _vm.handleShortcutClick(shortcut) } } }, [_vm._v(_vm._s(shortcut.text))] ) }), 0 ) : _vm._e(), _c("div", { staticClass: "el-picker-panel__body" }, [ _c( "div", { staticClass: "el-picker-panel__content el-date-range-picker__content is-left" }, [ _c("div", { staticClass: "el-date-range-picker__header" }, [ _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-d-arrow-left", attrs: { type: "button" }, on: { click: _vm.leftPrevYear } }), _vm.unlinkPanels ? _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-d-arrow-right", class: { "is-disabled": !_vm.enableYearArrow }, attrs: { type: "button", disabled: !_vm.enableYearArrow }, on: { click: _vm.leftNextYear } }) : _vm._e(), _c("div", [_vm._v(_vm._s(_vm.leftLabel))]) ]), _c("month-table", { attrs: { "selection-mode": "range", date: _vm.leftDate, "default-value": _vm.defaultValue, "min-date": _vm.minDate, "max-date": _vm.maxDate, "range-state": _vm.rangeState, "disabled-date": _vm.disabledDate }, on: { changerange: _vm.handleChangeRange, pick: _vm.handleRangePick } }) ], 1 ), _c( "div", { staticClass: "el-picker-panel__content el-date-range-picker__content is-right" }, [ _c("div", { staticClass: "el-date-range-picker__header" }, [ _vm.unlinkPanels ? _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-d-arrow-left", class: { "is-disabled": !_vm.enableYearArrow }, attrs: { type: "button", disabled: !_vm.enableYearArrow }, on: { click: _vm.rightPrevYear } }) : _vm._e(), _c("button", { staticClass: "el-picker-panel__icon-btn el-icon-d-arrow-right", attrs: { type: "button" }, on: { click: _vm.rightNextYear } }), _c("div", [_vm._v(_vm._s(_vm.rightLabel))]) ]), _c("month-table", { attrs: { "selection-mode": "range", date: _vm.rightDate, "default-value": _vm.defaultValue, "min-date": _vm.minDate, "max-date": _vm.maxDate, "range-state": _vm.rangeState, "disabled-date": _vm.disabledDate }, on: { changerange: _vm.handleChangeRange, pick: _vm.handleRangePick } }) ], 1 ) ]) ], 2 ) ] ) ] ) } var month_rangevue_type_template_id_f2645fb8_staticRenderFns = [] month_rangevue_type_template_id_f2645fb8_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/panel/month-range.vue?vue&type=template&id=f2645fb8& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/month-range.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var month_rangevue_type_script_lang_js_calcDefaultValue = function calcDefaultValue(defaultValue) { if (Array.isArray(defaultValue)) { return [new Date(defaultValue[0]), new Date(defaultValue[1])]; } else if (defaultValue) { return [new Date(defaultValue), Object(date_util_["nextMonth"])(new Date(defaultValue))]; } else { return [new Date(), Object(date_util_["nextMonth"])(new Date())]; } }; /* harmony default export */ var month_rangevue_type_script_lang_js_ = ({ mixins: [locale_default.a], directives: { Clickoutside: clickoutside_default.a }, computed: { btnDisabled: function btnDisabled() { return !(this.minDate && this.maxDate && !this.selecting && this.isValidValue([this.minDate, this.maxDate])); }, leftLabel: function leftLabel() { return this.leftDate.getFullYear() + ' ' + this.t('el.datepicker.year'); }, rightLabel: function rightLabel() { return this.rightDate.getFullYear() + ' ' + this.t('el.datepicker.year'); }, leftYear: function leftYear() { return this.leftDate.getFullYear(); }, rightYear: function rightYear() { return this.rightDate.getFullYear() === this.leftDate.getFullYear() ? this.leftDate.getFullYear() + 1 : this.rightDate.getFullYear(); }, enableYearArrow: function enableYearArrow() { return this.unlinkPanels && this.rightYear > this.leftYear + 1; } }, data: function data() { return { popperClass: '', value: [], defaultValue: null, defaultTime: null, minDate: '', maxDate: '', leftDate: new Date(), rightDate: Object(date_util_["nextYear"])(new Date()), rangeState: { endDate: null, selecting: false, row: null, column: null }, shortcuts: '', visible: '', disabledDate: '', format: '', arrowControl: false, unlinkPanels: false }; }, watch: { value: function value(newVal) { if (!newVal) { this.minDate = null; this.maxDate = null; } else if (Array.isArray(newVal)) { this.minDate = Object(date_util_["isDate"])(newVal[0]) ? new Date(newVal[0]) : null; this.maxDate = Object(date_util_["isDate"])(newVal[1]) ? new Date(newVal[1]) : null; if (this.minDate) { this.leftDate = this.minDate; if (this.unlinkPanels && this.maxDate) { var minDateYear = this.minDate.getFullYear(); var maxDateYear = this.maxDate.getFullYear(); this.rightDate = minDateYear === maxDateYear ? Object(date_util_["nextYear"])(this.maxDate) : this.maxDate; } else { this.rightDate = Object(date_util_["nextYear"])(this.leftDate); } } else { this.leftDate = month_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0]; this.rightDate = Object(date_util_["nextYear"])(this.leftDate); } } }, defaultValue: function defaultValue(val) { if (!Array.isArray(this.value)) { var _calcDefaultValue = month_rangevue_type_script_lang_js_calcDefaultValue(val), left = _calcDefaultValue[0], right = _calcDefaultValue[1]; this.leftDate = left; this.rightDate = val && val[1] && left.getFullYear() !== right.getFullYear() && this.unlinkPanels ? right : Object(date_util_["nextYear"])(this.leftDate); } } }, methods: { handleClear: function handleClear() { this.minDate = null; this.maxDate = null; this.leftDate = month_rangevue_type_script_lang_js_calcDefaultValue(this.defaultValue)[0]; this.rightDate = Object(date_util_["nextYear"])(this.leftDate); this.$emit('pick', null); }, handleChangeRange: function handleChangeRange(val) { this.minDate = val.minDate; this.maxDate = val.maxDate; this.rangeState = val.rangeState; }, handleRangePick: function handleRangePick(val) { var _this = this; var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; var defaultTime = this.defaultTime || []; var minDate = Object(date_util_["modifyWithTimeString"])(val.minDate, defaultTime[0]); var maxDate = Object(date_util_["modifyWithTimeString"])(val.maxDate, defaultTime[1]); if (this.maxDate === maxDate && this.minDate === minDate) { return; } this.onPick && this.onPick(val); this.maxDate = maxDate; this.minDate = minDate; // workaround for https://github.com/ElemeFE/element/issues/7539, should remove this block when we don't have to care about Chromium 55 - 57 setTimeout(function () { _this.maxDate = maxDate; _this.minDate = minDate; }, 10); if (!close) return; this.handleConfirm(); }, handleShortcutClick: function handleShortcutClick(shortcut) { if (shortcut.onClick) { shortcut.onClick(this); } }, // leftPrev*, rightNext* need to take care of `unlinkPanels` leftPrevYear: function leftPrevYear() { this.leftDate = Object(date_util_["prevYear"])(this.leftDate); if (!this.unlinkPanels) { this.rightDate = Object(date_util_["prevYear"])(this.rightDate); } }, rightNextYear: function rightNextYear() { if (!this.unlinkPanels) { this.leftDate = Object(date_util_["nextYear"])(this.leftDate); } this.rightDate = Object(date_util_["nextYear"])(this.rightDate); }, // leftNext*, rightPrev* are called when `unlinkPanels` is true leftNextYear: function leftNextYear() { this.leftDate = Object(date_util_["nextYear"])(this.leftDate); }, rightPrevYear: function rightPrevYear() { this.rightDate = Object(date_util_["prevYear"])(this.rightDate); }, handleConfirm: function handleConfirm() { var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; if (this.isValidValue([this.minDate, this.maxDate])) { this.$emit('pick', [this.minDate, this.maxDate], visible); } }, isValidValue: function isValidValue(value) { return Array.isArray(value) && value && value[0] && value[1] && Object(date_util_["isDate"])(value[0]) && Object(date_util_["isDate"])(value[1]) && value[0].getTime() <= value[1].getTime() && (typeof this.disabledDate === 'function' ? !this.disabledDate(value[0]) && !this.disabledDate(value[1]) : true); }, resetView: function resetView() { // NOTE: this is a hack to reset {min, max}Date on picker open. // TODO: correct way of doing so is to refactor {min, max}Date to be dependent on value and internal selection state // an alternative would be resetView whenever picker becomes visible, should also investigate date-panel's resetView this.minDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[0]) : null; this.maxDate = this.value && Object(date_util_["isDate"])(this.value[0]) ? new Date(this.value[1]) : null; } }, components: { MonthTable: month_table, ElInput: input_default.a, ElButton: button_default.a } }); // CONCATENATED MODULE: ./packages/date-picker/src/panel/month-range.vue?vue&type=script&lang=js& /* harmony default export */ var panel_month_rangevue_type_script_lang_js_ = (month_rangevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/panel/month-range.vue /* normalize component */ var month_range_component = normalizeComponent( panel_month_rangevue_type_script_lang_js_, month_rangevue_type_template_id_f2645fb8_render, month_rangevue_type_template_id_f2645fb8_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var month_range_api; } month_range_component.options.__file = "packages/date-picker/src/panel/month-range.vue" /* harmony default export */ var month_range = (month_range_component.exports); // CONCATENATED MODULE: ./packages/date-picker/src/picker/date-picker.js var date_picker_getPanel = function getPanel(type) { if (type === 'daterange' || type === 'datetimerange') { return date_range; } else if (type === 'monthrange') { return month_range; } return panel_date; }; /* harmony default export */ var date_picker = ({ mixins: [picker], name: 'ElDatePicker', props: { type: { type: String, default: 'date' }, timeArrowControl: Boolean }, watch: { type: function type(_type) { if (this.picker) { this.unmountPicker(); this.panel = date_picker_getPanel(_type); this.mountPicker(); } else { this.panel = date_picker_getPanel(_type); } } }, created: function created() { this.panel = date_picker_getPanel(this.type); } }); // CONCATENATED MODULE: ./packages/date-picker/index.js /* istanbul ignore next */ date_picker.install = function install(Vue) { Vue.component(date_picker.name, date_picker); }; /* harmony default export */ var packages_date_picker = (date_picker); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time-select.vue?vue&type=template&id=51ab9320& var time_selectvue_type_template_id_51ab9320_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "before-enter": _vm.handleMenuEnter, "after-leave": function($event) { _vm.$emit("dodestroy") } } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], ref: "popper", staticClass: "el-picker-panel time-select el-popper", class: _vm.popperClass, style: { width: _vm.width + "px" } }, [ _c( "el-scrollbar", { attrs: { noresize: "", "wrap-class": "el-picker-panel__content" } }, _vm._l(_vm.items, function(item) { return _c( "div", { key: item.value, staticClass: "time-select-item", class: { selected: _vm.value === item.value, disabled: item.disabled, default: item.value === _vm.defaultValue }, attrs: { disabled: item.disabled }, on: { click: function($event) { _vm.handleClick(item) } } }, [_vm._v(_vm._s(item.value))] ) }), 0 ) ], 1 ) ] ) } var time_selectvue_type_template_id_51ab9320_staticRenderFns = [] time_selectvue_type_template_id_51ab9320_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-select.vue?vue&type=template&id=51ab9320& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time-select.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // var parseTime = function parseTime(time) { var values = (time || '').split(':'); if (values.length >= 2) { var hours = parseInt(values[0], 10); var minutes = parseInt(values[1], 10); return { hours: hours, minutes: minutes }; } /* istanbul ignore next */ return null; }; var compareTime = function compareTime(time1, time2) { var value1 = parseTime(time1); var value2 = parseTime(time2); var minutes1 = value1.minutes + value1.hours * 60; var minutes2 = value2.minutes + value2.hours * 60; if (minutes1 === minutes2) { return 0; } return minutes1 > minutes2 ? 1 : -1; }; var formatTime = function formatTime(time) { return (time.hours < 10 ? '0' + time.hours : time.hours) + ':' + (time.minutes < 10 ? '0' + time.minutes : time.minutes); }; var nextTime = function nextTime(time, step) { var timeValue = parseTime(time); var stepValue = parseTime(step); var next = { hours: timeValue.hours, minutes: timeValue.minutes }; next.minutes += stepValue.minutes; next.hours += stepValue.hours; next.hours += Math.floor(next.minutes / 60); next.minutes = next.minutes % 60; return formatTime(next); }; /* harmony default export */ var time_selectvue_type_script_lang_js_ = ({ components: { ElScrollbar: scrollbar_default.a }, watch: { value: function value(val) { var _this = this; if (!val) return; this.$nextTick(function () { return _this.scrollToOption(); }); } }, methods: { handleClick: function handleClick(item) { if (!item.disabled) { this.$emit('pick', item.value); } }, handleClear: function handleClear() { this.$emit('pick', null); }, scrollToOption: function scrollToOption() { var selector = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '.selected'; var menu = this.$refs.popper.querySelector('.el-picker-panel__content'); scroll_into_view_default()(menu, menu.querySelector(selector)); }, handleMenuEnter: function handleMenuEnter() { var _this2 = this; var selected = this.items.map(function (item) { return item.value; }).indexOf(this.value) !== -1; var hasDefault = this.items.map(function (item) { return item.value; }).indexOf(this.defaultValue) !== -1; var option = selected && '.selected' || hasDefault && '.default' || '.time-select-item:not(.disabled)'; this.$nextTick(function () { return _this2.scrollToOption(option); }); }, scrollDown: function scrollDown(step) { var items = this.items; var length = items.length; var total = items.length; var index = items.map(function (item) { return item.value; }).indexOf(this.value); while (total--) { index = (index + step + length) % length; if (!items[index].disabled) { this.$emit('pick', items[index].value, true); return; } } }, isValidValue: function isValidValue(date) { return this.items.filter(function (item) { return !item.disabled; }).map(function (item) { return item.value; }).indexOf(date) !== -1; }, handleKeydown: function handleKeydown(event) { var keyCode = event.keyCode; if (keyCode === 38 || keyCode === 40) { var mapping = { 40: 1, 38: -1 }; var offset = mapping[keyCode.toString()]; this.scrollDown(offset); event.stopPropagation(); return; } } }, data: function data() { return { popperClass: '', start: '09:00', end: '18:00', step: '00:30', value: '', defaultValue: '', visible: false, minTime: '', maxTime: '', width: 0 }; }, computed: { items: function items() { var start = this.start; var end = this.end; var step = this.step; var result = []; if (start && end && step) { var current = start; while (compareTime(current, end) <= 0) { result.push({ value: current, disabled: compareTime(current, this.minTime || '-1:-1') <= 0 || compareTime(current, this.maxTime || '100:100') >= 0 }); current = nextTime(current, step); } } return result; } } }); // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-select.vue?vue&type=script&lang=js& /* harmony default export */ var panel_time_selectvue_type_script_lang_js_ = (time_selectvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-select.vue /* normalize component */ var time_select_component = normalizeComponent( panel_time_selectvue_type_script_lang_js_, time_selectvue_type_template_id_51ab9320_render, time_selectvue_type_template_id_51ab9320_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var time_select_api; } time_select_component.options.__file = "packages/date-picker/src/panel/time-select.vue" /* harmony default export */ var time_select = (time_select_component.exports); // CONCATENATED MODULE: ./packages/date-picker/src/picker/time-select.js /* harmony default export */ var picker_time_select = ({ mixins: [picker], name: 'ElTimeSelect', componentName: 'ElTimeSelect', props: { type: { type: String, default: 'time-select' } }, beforeCreate: function beforeCreate() { this.panel = time_select; } }); // CONCATENATED MODULE: ./packages/time-select/index.js /* istanbul ignore next */ picker_time_select.install = function (Vue) { Vue.component(picker_time_select.name, picker_time_select); }; /* harmony default export */ var packages_time_select = (picker_time_select); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time-range.vue?vue&type=template&id=fb28660e& var time_rangevue_type_template_id_fb28660e_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": function($event) { _vm.$emit("dodestroy") } } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-time-range-picker el-picker-panel el-popper", class: _vm.popperClass }, [ _c("div", { staticClass: "el-time-range-picker__content" }, [ _c("div", { staticClass: "el-time-range-picker__cell" }, [ _c("div", { staticClass: "el-time-range-picker__header" }, [ _vm._v(_vm._s(_vm.t("el.datepicker.startTime"))) ]), _c( "div", { staticClass: "el-time-range-picker__body el-time-panel__content", class: { "has-seconds": _vm.showSeconds, "is-arrow": _vm.arrowControl } }, [ _c("time-spinner", { ref: "minSpinner", attrs: { "show-seconds": _vm.showSeconds, "am-pm-mode": _vm.amPmMode, "arrow-control": _vm.arrowControl, date: _vm.minDate }, on: { change: _vm.handleMinChange, "select-range": _vm.setMinSelectionRange } }) ], 1 ) ]), _c("div", { staticClass: "el-time-range-picker__cell" }, [ _c("div", { staticClass: "el-time-range-picker__header" }, [ _vm._v(_vm._s(_vm.t("el.datepicker.endTime"))) ]), _c( "div", { staticClass: "el-time-range-picker__body el-time-panel__content", class: { "has-seconds": _vm.showSeconds, "is-arrow": _vm.arrowControl } }, [ _c("time-spinner", { ref: "maxSpinner", attrs: { "show-seconds": _vm.showSeconds, "am-pm-mode": _vm.amPmMode, "arrow-control": _vm.arrowControl, date: _vm.maxDate }, on: { change: _vm.handleMaxChange, "select-range": _vm.setMaxSelectionRange } }) ], 1 ) ]) ]), _c("div", { staticClass: "el-time-panel__footer" }, [ _c( "button", { staticClass: "el-time-panel__btn cancel", attrs: { type: "button" }, on: { click: function($event) { _vm.handleCancel() } } }, [_vm._v(_vm._s(_vm.t("el.datepicker.cancel")))] ), _c( "button", { staticClass: "el-time-panel__btn confirm", attrs: { type: "button", disabled: _vm.btnDisabled }, on: { click: function($event) { _vm.handleConfirm() } } }, [_vm._v(_vm._s(_vm.t("el.datepicker.confirm")))] ) ]) ] ) ] ) } var time_rangevue_type_template_id_fb28660e_staticRenderFns = [] time_rangevue_type_template_id_fb28660e_render._withStripped = true // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-range.vue?vue&type=template&id=fb28660e& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/date-picker/src/panel/time-range.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var MIN_TIME = Object(date_util_["parseDate"])('00:00:00', 'HH:mm:ss'); var MAX_TIME = Object(date_util_["parseDate"])('23:59:59', 'HH:mm:ss'); var time_rangevue_type_script_lang_js_minTimeOfDay = function minTimeOfDay(date) { return Object(date_util_["modifyDate"])(MIN_TIME, date.getFullYear(), date.getMonth(), date.getDate()); }; var time_rangevue_type_script_lang_js_maxTimeOfDay = function maxTimeOfDay(date) { return Object(date_util_["modifyDate"])(MAX_TIME, date.getFullYear(), date.getMonth(), date.getDate()); }; // increase time by amount of milliseconds, but within the range of day var advanceTime = function advanceTime(date, amount) { return new Date(Math.min(date.getTime() + amount, time_rangevue_type_script_lang_js_maxTimeOfDay(date).getTime())); }; /* harmony default export */ var time_rangevue_type_script_lang_js_ = ({ mixins: [locale_default.a], components: { TimeSpinner: time_spinner }, computed: { showSeconds: function showSeconds() { return (this.format || '').indexOf('ss') !== -1; }, offset: function offset() { return this.showSeconds ? 11 : 8; }, spinner: function spinner() { return this.selectionRange[0] < this.offset ? this.$refs.minSpinner : this.$refs.maxSpinner; }, btnDisabled: function btnDisabled() { return this.minDate.getTime() > this.maxDate.getTime(); }, amPmMode: function amPmMode() { if ((this.format || '').indexOf('A') !== -1) return 'A'; if ((this.format || '').indexOf('a') !== -1) return 'a'; return ''; } }, data: function data() { return { popperClass: '', minDate: new Date(), maxDate: new Date(), value: [], oldValue: [new Date(), new Date()], defaultValue: null, format: 'HH:mm:ss', visible: false, selectionRange: [0, 2], arrowControl: false }; }, watch: { value: function value(_value) { if (Array.isArray(_value)) { this.minDate = new Date(_value[0]); this.maxDate = new Date(_value[1]); } else { if (Array.isArray(this.defaultValue)) { this.minDate = new Date(this.defaultValue[0]); this.maxDate = new Date(this.defaultValue[1]); } else if (this.defaultValue) { this.minDate = new Date(this.defaultValue); this.maxDate = advanceTime(new Date(this.defaultValue), 60 * 60 * 1000); } else { this.minDate = new Date(); this.maxDate = advanceTime(new Date(), 60 * 60 * 1000); } } }, visible: function visible(val) { var _this = this; if (val) { this.oldValue = this.value; this.$nextTick(function () { return _this.$refs.minSpinner.emitSelectRange('hours'); }); } } }, methods: { handleClear: function handleClear() { this.$emit('pick', null); }, handleCancel: function handleCancel() { this.$emit('pick', this.oldValue); }, handleMinChange: function handleMinChange(date) { this.minDate = Object(date_util_["clearMilliseconds"])(date); this.handleChange(); }, handleMaxChange: function handleMaxChange(date) { this.maxDate = Object(date_util_["clearMilliseconds"])(date); this.handleChange(); }, handleChange: function handleChange() { if (this.isValidValue([this.minDate, this.maxDate])) { this.$refs.minSpinner.selectableRange = [[time_rangevue_type_script_lang_js_minTimeOfDay(this.minDate), this.maxDate]]; this.$refs.maxSpinner.selectableRange = [[this.minDate, time_rangevue_type_script_lang_js_maxTimeOfDay(this.maxDate)]]; this.$emit('pick', [this.minDate, this.maxDate], true); } }, setMinSelectionRange: function setMinSelectionRange(start, end) { this.$emit('select-range', start, end, 'min'); this.selectionRange = [start, end]; }, setMaxSelectionRange: function setMaxSelectionRange(start, end) { this.$emit('select-range', start, end, 'max'); this.selectionRange = [start + this.offset, end + this.offset]; }, handleConfirm: function handleConfirm() { var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; var minSelectableRange = this.$refs.minSpinner.selectableRange; var maxSelectableRange = this.$refs.maxSpinner.selectableRange; this.minDate = Object(date_util_["limitTimeRange"])(this.minDate, minSelectableRange, this.format); this.maxDate = Object(date_util_["limitTimeRange"])(this.maxDate, maxSelectableRange, this.format); this.$emit('pick', [this.minDate, this.maxDate], visible); }, adjustSpinners: function adjustSpinners() { this.$refs.minSpinner.adjustSpinners(); this.$refs.maxSpinner.adjustSpinners(); }, changeSelectionRange: function changeSelectionRange(step) { var list = this.showSeconds ? [0, 3, 6, 11, 14, 17] : [0, 3, 8, 11]; var mapping = ['hours', 'minutes'].concat(this.showSeconds ? ['seconds'] : []); var index = list.indexOf(this.selectionRange[0]); var next = (index + step + list.length) % list.length; var half = list.length / 2; if (next < half) { this.$refs.minSpinner.emitSelectRange(mapping[next]); } else { this.$refs.maxSpinner.emitSelectRange(mapping[next - half]); } }, isValidValue: function isValidValue(date) { return Array.isArray(date) && Object(date_util_["timeWithinRange"])(this.minDate, this.$refs.minSpinner.selectableRange) && Object(date_util_["timeWithinRange"])(this.maxDate, this.$refs.maxSpinner.selectableRange); }, handleKeydown: function handleKeydown(event) { var keyCode = event.keyCode; var mapping = { 38: -1, 40: 1, 37: -1, 39: 1 }; // Left or Right if (keyCode === 37 || keyCode === 39) { var step = mapping[keyCode]; this.changeSelectionRange(step); event.preventDefault(); return; } // Up or Down if (keyCode === 38 || keyCode === 40) { var _step = mapping[keyCode]; this.spinner.scrollDown(_step); event.preventDefault(); return; } } } }); // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-range.vue?vue&type=script&lang=js& /* harmony default export */ var panel_time_rangevue_type_script_lang_js_ = (time_rangevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/date-picker/src/panel/time-range.vue /* normalize component */ var time_range_component = normalizeComponent( panel_time_rangevue_type_script_lang_js_, time_rangevue_type_template_id_fb28660e_render, time_rangevue_type_template_id_fb28660e_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var time_range_api; } time_range_component.options.__file = "packages/date-picker/src/panel/time-range.vue" /* harmony default export */ var time_range = (time_range_component.exports); // CONCATENATED MODULE: ./packages/date-picker/src/picker/time-picker.js /* harmony default export */ var time_picker = ({ mixins: [picker], name: 'ElTimePicker', props: { isRange: Boolean, arrowControl: Boolean }, data: function data() { return { type: '' }; }, watch: { isRange: function isRange(_isRange) { if (this.picker) { this.unmountPicker(); this.type = _isRange ? 'timerange' : 'time'; this.panel = _isRange ? time_range : panel_time; this.mountPicker(); } else { this.type = _isRange ? 'timerange' : 'time'; this.panel = _isRange ? time_range : panel_time; } } }, created: function created() { this.type = this.isRange ? 'timerange' : 'time'; this.panel = this.isRange ? time_range : panel_time; } }); // CONCATENATED MODULE: ./packages/time-picker/index.js /* istanbul ignore next */ time_picker.install = function (Vue) { Vue.component(time_picker.name, time_picker); }; /* harmony default export */ var packages_time_picker = (time_picker); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/popover/src/main.vue?vue&type=template&id=52060272& var mainvue_type_template_id_52060272_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "span", [ _c( "transition", { attrs: { name: _vm.transition }, on: { "after-enter": _vm.handleAfterEnter, "after-leave": _vm.handleAfterLeave } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: !_vm.disabled && _vm.showPopper, expression: "!disabled && showPopper" } ], ref: "popper", staticClass: "el-popover el-popper", class: [_vm.popperClass, _vm.content && "el-popover--plain"], style: { width: _vm.width + "px" }, attrs: { role: "tooltip", id: _vm.tooltipId, "aria-hidden": _vm.disabled || !_vm.showPopper ? "true" : "false" } }, [ _vm.title ? _c("div", { staticClass: "el-popover__title", domProps: { textContent: _vm._s(_vm.title) } }) : _vm._e(), _vm._t("default", [_vm._v(_vm._s(_vm.content))]) ], 2 ) ] ), _vm._t("reference") ], 2 ) } var mainvue_type_template_id_52060272_staticRenderFns = [] mainvue_type_template_id_52060272_render._withStripped = true // CONCATENATED MODULE: ./packages/popover/src/main.vue?vue&type=template&id=52060272& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/popover/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var mainvue_type_script_lang_js_ = ({ name: 'ElPopover', mixins: [vue_popper_default.a], props: { trigger: { type: String, default: 'click', validator: function validator(value) { return ['click', 'focus', 'hover', 'manual'].indexOf(value) > -1; } }, openDelay: { type: Number, default: 0 }, closeDelay: { type: Number, default: 200 }, title: String, disabled: Boolean, content: String, reference: {}, popperClass: String, width: {}, visibleArrow: { default: true }, arrowOffset: { type: Number, default: 0 }, transition: { type: String, default: 'fade-in-linear' }, tabindex: { type: Number, default: 0 } }, computed: { tooltipId: function tooltipId() { return 'el-popover-' + Object(util_["generateId"])(); } }, watch: { showPopper: function showPopper(val) { if (this.disabled) { return; } val ? this.$emit('show') : this.$emit('hide'); } }, mounted: function mounted() { var _this = this; var reference = this.referenceElm = this.reference || this.$refs.reference; var popper = this.popper || this.$refs.popper; if (!reference && this.$slots.reference && this.$slots.reference[0]) { reference = this.referenceElm = this.$slots.reference[0].elm; } // 可访问性 if (reference) { Object(dom_["addClass"])(reference, 'el-popover__reference'); reference.setAttribute('aria-describedby', this.tooltipId); reference.setAttribute('tabindex', this.tabindex); // tab序列 popper.setAttribute('tabindex', 0); if (this.trigger !== 'click') { Object(dom_["on"])(reference, 'focusin', function () { _this.handleFocus(); var instance = reference.__vue__; if (instance && typeof instance.focus === 'function') { instance.focus(); } }); Object(dom_["on"])(popper, 'focusin', this.handleFocus); Object(dom_["on"])(reference, 'focusout', this.handleBlur); Object(dom_["on"])(popper, 'focusout', this.handleBlur); } Object(dom_["on"])(reference, 'keydown', this.handleKeydown); Object(dom_["on"])(reference, 'click', this.handleClick); } if (this.trigger === 'click') { Object(dom_["on"])(reference, 'click', this.doToggle); Object(dom_["on"])(document, 'click', this.handleDocumentClick); } else if (this.trigger === 'hover') { Object(dom_["on"])(reference, 'mouseenter', this.handleMouseEnter); Object(dom_["on"])(popper, 'mouseenter', this.handleMouseEnter); Object(dom_["on"])(reference, 'mouseleave', this.handleMouseLeave); Object(dom_["on"])(popper, 'mouseleave', this.handleMouseLeave); } else if (this.trigger === 'focus') { if (this.tabindex < 0) { console.warn('[Element Warn][Popover]a negative taindex means that the element cannot be focused by tab key'); } if (reference.querySelector('input, textarea')) { Object(dom_["on"])(reference, 'focusin', this.doShow); Object(dom_["on"])(reference, 'focusout', this.doClose); } else { Object(dom_["on"])(reference, 'mousedown', this.doShow); Object(dom_["on"])(reference, 'mouseup', this.doClose); } } }, beforeDestroy: function beforeDestroy() { this.cleanup(); }, deactivated: function deactivated() { this.cleanup(); }, methods: { doToggle: function doToggle() { this.showPopper = !this.showPopper; }, doShow: function doShow() { this.showPopper = true; }, doClose: function doClose() { this.showPopper = false; }, handleFocus: function handleFocus() { Object(dom_["addClass"])(this.referenceElm, 'focusing'); if (this.trigger === 'click' || this.trigger === 'focus') this.showPopper = true; }, handleClick: function handleClick() { Object(dom_["removeClass"])(this.referenceElm, 'focusing'); }, handleBlur: function handleBlur() { Object(dom_["removeClass"])(this.referenceElm, 'focusing'); if (this.trigger === 'click' || this.trigger === 'focus') this.showPopper = false; }, handleMouseEnter: function handleMouseEnter() { var _this2 = this; clearTimeout(this._timer); if (this.openDelay) { this._timer = setTimeout(function () { _this2.showPopper = true; }, this.openDelay); } else { this.showPopper = true; } }, handleKeydown: function handleKeydown(ev) { if (ev.keyCode === 27 && this.trigger !== 'manual') { // esc this.doClose(); } }, handleMouseLeave: function handleMouseLeave() { var _this3 = this; clearTimeout(this._timer); if (this.closeDelay) { this._timer = setTimeout(function () { _this3.showPopper = false; }, this.closeDelay); } else { this.showPopper = false; } }, handleDocumentClick: function handleDocumentClick(e) { var reference = this.reference || this.$refs.reference; var popper = this.popper || this.$refs.popper; if (!reference && this.$slots.reference && this.$slots.reference[0]) { reference = this.referenceElm = this.$slots.reference[0].elm; } if (!this.$el || !reference || this.$el.contains(e.target) || reference.contains(e.target) || !popper || popper.contains(e.target)) return; this.showPopper = false; }, handleAfterEnter: function handleAfterEnter() { this.$emit('after-enter'); }, handleAfterLeave: function handleAfterLeave() { this.$emit('after-leave'); this.doDestroy(); }, cleanup: function cleanup() { if (this.openDelay || this.closeDelay) { clearTimeout(this._timer); } } }, destroyed: function destroyed() { var reference = this.reference; Object(dom_["off"])(reference, 'click', this.doToggle); Object(dom_["off"])(reference, 'mouseup', this.doClose); Object(dom_["off"])(reference, 'mousedown', this.doShow); Object(dom_["off"])(reference, 'focusin', this.doShow); Object(dom_["off"])(reference, 'focusout', this.doClose); Object(dom_["off"])(reference, 'mousedown', this.doShow); Object(dom_["off"])(reference, 'mouseup', this.doClose); Object(dom_["off"])(reference, 'mouseleave', this.handleMouseLeave); Object(dom_["off"])(reference, 'mouseenter', this.handleMouseEnter); Object(dom_["off"])(document, 'click', this.handleDocumentClick); } }); // CONCATENATED MODULE: ./packages/popover/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var src_mainvue_type_script_lang_js_ = (mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/popover/src/main.vue /* normalize component */ var main_component = normalizeComponent( src_mainvue_type_script_lang_js_, mainvue_type_template_id_52060272_render, mainvue_type_template_id_52060272_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var main_api; } main_component.options.__file = "packages/popover/src/main.vue" /* harmony default export */ var main = (main_component.exports); // CONCATENATED MODULE: ./packages/popover/src/directive.js var getReference = function getReference(el, binding, vnode) { var _ref = binding.expression ? binding.value : binding.arg; var popper = vnode.context.$refs[_ref]; if (popper) { if (Array.isArray(popper)) { popper[0].$refs.reference = el; } else { popper.$refs.reference = el; } } }; /* harmony default export */ var directive = ({ bind: function bind(el, binding, vnode) { getReference(el, binding, vnode); }, inserted: function inserted(el, binding, vnode) { getReference(el, binding, vnode); } }); // CONCATENATED MODULE: ./packages/popover/index.js external_vue_default.a.directive('popover', directive); /* istanbul ignore next */ main.install = function (Vue) { Vue.directive('popover', directive); Vue.component(main.name, main); }; main.directive = directive; /* harmony default export */ var popover = (main); // CONCATENATED MODULE: ./packages/tooltip/src/main.js /* harmony default export */ var src_main = ({ name: 'ElTooltip', mixins: [vue_popper_default.a], props: { openDelay: { type: Number, default: 0 }, disabled: Boolean, manual: Boolean, effect: { type: String, default: 'dark' }, arrowOffset: { type: Number, default: 0 }, popperClass: String, content: String, visibleArrow: { default: true }, transition: { type: String, default: 'el-fade-in-linear' }, popperOptions: { default: function _default() { return { boundariesPadding: 10, gpuAcceleration: false }; } }, enterable: { type: Boolean, default: true }, hideAfter: { type: Number, default: 0 }, tabindex: { type: Number, default: 0 } }, data: function data() { return { tooltipId: 'el-tooltip-' + Object(util_["generateId"])(), timeoutPending: null, focusing: false }; }, beforeCreate: function beforeCreate() { var _this = this; if (this.$isServer) return; this.popperVM = new external_vue_default.a({ data: { node: '' }, render: function render(h) { return this.node; } }).$mount(); this.debounceClose = debounce_default()(200, function () { return _this.handleClosePopper(); }); }, render: function render(h) { var _this2 = this; if (this.popperVM) { this.popperVM.node = h( 'transition', { attrs: { name: this.transition }, on: { 'afterLeave': this.doDestroy } }, [h( 'div', { on: { 'mouseleave': function mouseleave() { _this2.setExpectedState(false);_this2.debounceClose(); }, 'mouseenter': function mouseenter() { _this2.setExpectedState(true); } }, ref: 'popper', attrs: { role: 'tooltip', id: this.tooltipId, 'aria-hidden': this.disabled || !this.showPopper ? 'true' : 'false' }, directives: [{ name: 'show', value: !this.disabled && this.showPopper }], 'class': ['el-tooltip__popper', 'is-' + this.effect, this.popperClass] }, [this.$slots.content || this.content] )] ); } var firstElement = this.getFirstElement(); if (!firstElement) return null; var data = firstElement.data = firstElement.data || {}; data.staticClass = this.addTooltipClass(data.staticClass); return firstElement; }, mounted: function mounted() { var _this3 = this; this.referenceElm = this.$el; if (this.$el.nodeType === 1) { this.$el.setAttribute('aria-describedby', this.tooltipId); this.$el.setAttribute('tabindex', this.tabindex); Object(dom_["on"])(this.referenceElm, 'mouseenter', this.show); Object(dom_["on"])(this.referenceElm, 'mouseleave', this.hide); Object(dom_["on"])(this.referenceElm, 'focus', function () { if (!_this3.$slots.default || !_this3.$slots.default.length) { _this3.handleFocus(); return; } var instance = _this3.$slots.default[0].componentInstance; if (instance && instance.focus) { instance.focus(); } else { _this3.handleFocus(); } }); Object(dom_["on"])(this.referenceElm, 'blur', this.handleBlur); Object(dom_["on"])(this.referenceElm, 'click', this.removeFocusing); } // fix issue https://github.com/ElemeFE/element/issues/14424 if (this.value && this.popperVM) { this.popperVM.$nextTick(function () { if (_this3.value) { _this3.updatePopper(); } }); } }, watch: { focusing: function focusing(val) { if (val) { Object(dom_["addClass"])(this.referenceElm, 'focusing'); } else { Object(dom_["removeClass"])(this.referenceElm, 'focusing'); } } }, methods: { show: function show() { this.setExpectedState(true); this.handleShowPopper(); }, hide: function hide() { this.setExpectedState(false); this.debounceClose(); }, handleFocus: function handleFocus() { this.focusing = true; this.show(); }, handleBlur: function handleBlur() { this.focusing = false; this.hide(); }, removeFocusing: function removeFocusing() { this.focusing = false; }, addTooltipClass: function addTooltipClass(prev) { if (!prev) { return 'el-tooltip'; } else { return 'el-tooltip ' + prev.replace('el-tooltip', ''); } }, handleShowPopper: function handleShowPopper() { var _this4 = this; if (!this.expectedState || this.manual) return; clearTimeout(this.timeout); this.timeout = setTimeout(function () { _this4.showPopper = true; }, this.openDelay); if (this.hideAfter > 0) { this.timeoutPending = setTimeout(function () { _this4.showPopper = false; }, this.hideAfter); } }, handleClosePopper: function handleClosePopper() { if (this.enterable && this.expectedState || this.manual) return; clearTimeout(this.timeout); if (this.timeoutPending) { clearTimeout(this.timeoutPending); } this.showPopper = false; if (this.disabled) { this.doDestroy(); } }, setExpectedState: function setExpectedState(expectedState) { if (expectedState === false) { clearTimeout(this.timeoutPending); } this.expectedState = expectedState; }, getFirstElement: function getFirstElement() { var slots = this.$slots.default; if (!Array.isArray(slots)) return null; var element = null; for (var index = 0; index < slots.length; index++) { if (slots[index] && slots[index].tag) { element = slots[index]; }; } return element; } }, beforeDestroy: function beforeDestroy() { this.popperVM && this.popperVM.$destroy(); }, destroyed: function destroyed() { var reference = this.referenceElm; if (reference.nodeType === 1) { Object(dom_["off"])(reference, 'mouseenter', this.show); Object(dom_["off"])(reference, 'mouseleave', this.hide); Object(dom_["off"])(reference, 'focus', this.handleFocus); Object(dom_["off"])(reference, 'blur', this.handleBlur); Object(dom_["off"])(reference, 'click', this.removeFocusing); } } }); // CONCATENATED MODULE: ./packages/tooltip/index.js /* istanbul ignore next */ src_main.install = function (Vue) { Vue.component(src_main.name, src_main); }; /* harmony default export */ var packages_tooltip = (src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/message-box/src/main.vue?vue&type=template&id=6b29b012& var mainvue_type_template_id_6b29b012_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("transition", { attrs: { name: "msgbox-fade" } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-message-box__wrapper", attrs: { tabindex: "-1", role: "dialog", "aria-modal": "true", "aria-label": _vm.title || "dialog" }, on: { click: function($event) { if ($event.target !== $event.currentTarget) { return null } return _vm.handleWrapperClick($event) } } }, [ _c( "div", { staticClass: "el-message-box", class: [_vm.customClass, _vm.center && "el-message-box--center"] }, [ _vm.title !== null ? _c("div", { staticClass: "el-message-box__header" }, [ _c("div", { staticClass: "el-message-box__title" }, [ _vm.icon && _vm.center ? _c("div", { class: ["el-message-box__status", _vm.icon] }) : _vm._e(), _c("span", [_vm._v(_vm._s(_vm.title))]) ]), _vm.showClose ? _c( "button", { staticClass: "el-message-box__headerbtn", attrs: { type: "button", "aria-label": "Close" }, on: { click: function($event) { _vm.handleAction( _vm.distinguishCancelAndClose ? "close" : "cancel" ) }, keydown: function($event) { if ( !("button" in $event) && _vm._k( $event.keyCode, "enter", 13, $event.key, "Enter" ) ) { return null } _vm.handleAction( _vm.distinguishCancelAndClose ? "close" : "cancel" ) } } }, [ _c("i", { staticClass: "el-message-box__close el-icon-close" }) ] ) : _vm._e() ]) : _vm._e(), _c("div", { staticClass: "el-message-box__content" }, [ _c("div", { staticClass: "el-message-box__container" }, [ _vm.icon && !_vm.center && _vm.message !== "" ? _c("div", { class: ["el-message-box__status", _vm.icon] }) : _vm._e(), _vm.message !== "" ? _c( "div", { staticClass: "el-message-box__message" }, [ _vm._t("default", [ !_vm.dangerouslyUseHTMLString ? _c("p", [_vm._v(_vm._s(_vm.message))]) : _c("p", { domProps: { innerHTML: _vm._s(_vm.message) } }) ]) ], 2 ) : _vm._e() ]), _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.showInput, expression: "showInput" } ], staticClass: "el-message-box__input" }, [ _c("el-input", { ref: "input", attrs: { type: _vm.inputType, placeholder: _vm.inputPlaceholder }, nativeOn: { keydown: function($event) { if ( !("button" in $event) && _vm._k( $event.keyCode, "enter", 13, $event.key, "Enter" ) ) { return null } return _vm.handleInputEnter($event) } }, model: { value: _vm.inputValue, callback: function($$v) { _vm.inputValue = $$v }, expression: "inputValue" } }), _c( "div", { staticClass: "el-message-box__errormsg", style: { visibility: !!_vm.editorErrorMessage ? "visible" : "hidden" } }, [_vm._v(_vm._s(_vm.editorErrorMessage))] ) ], 1 ) ]), _c( "div", { staticClass: "el-message-box__btns" }, [ _vm.showCancelButton ? _c( "el-button", { class: [_vm.cancelButtonClasses], attrs: { loading: _vm.cancelButtonLoading, round: _vm.roundButton, size: "small" }, on: { keydown: function($event) { if ( !("button" in $event) && _vm._k( $event.keyCode, "enter", 13, $event.key, "Enter" ) ) { return null } _vm.handleAction("cancel") } }, nativeOn: { click: function($event) { _vm.handleAction("cancel") } } }, [ _vm._v( "\n " + _vm._s( _vm.cancelButtonText || _vm.t("el.messagebox.cancel") ) + "\n " ) ] ) : _vm._e(), _c( "el-button", { directives: [ { name: "show", rawName: "v-show", value: _vm.showConfirmButton, expression: "showConfirmButton" } ], ref: "confirm", class: [_vm.confirmButtonClasses], attrs: { loading: _vm.confirmButtonLoading, round: _vm.roundButton, size: "small" }, on: { keydown: function($event) { if ( !("button" in $event) && _vm._k( $event.keyCode, "enter", 13, $event.key, "Enter" ) ) { return null } _vm.handleAction("confirm") } }, nativeOn: { click: function($event) { _vm.handleAction("confirm") } } }, [ _vm._v( "\n " + _vm._s( _vm.confirmButtonText || _vm.t("el.messagebox.confirm") ) + "\n " ) ] ) ], 1 ) ] ) ] ) ]) } var mainvue_type_template_id_6b29b012_staticRenderFns = [] mainvue_type_template_id_6b29b012_render._withStripped = true // CONCATENATED MODULE: ./packages/message-box/src/main.vue?vue&type=template&id=6b29b012& // EXTERNAL MODULE: external "element-ui/lib/utils/aria-dialog" var aria_dialog_ = __webpack_require__(39); var aria_dialog_default = /*#__PURE__*/__webpack_require__.n(aria_dialog_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/message-box/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var messageBox = void 0; var typeMap = { success: 'success', info: 'info', warning: 'warning', error: 'error' }; /* harmony default export */ var message_box_src_mainvue_type_script_lang_js_ = ({ mixins: [popup_default.a, locale_default.a], props: { modal: { default: true }, lockScroll: { default: true }, showClose: { type: Boolean, default: true }, closeOnClickModal: { default: true }, closeOnPressEscape: { default: true }, closeOnHashChange: { default: true }, center: { default: false, type: Boolean }, roundButton: { default: false, type: Boolean } }, components: { ElInput: input_default.a, ElButton: button_default.a }, computed: { icon: function icon() { var type = this.type, iconClass = this.iconClass; return iconClass || (type && typeMap[type] ? 'el-icon-' + typeMap[type] : ''); }, confirmButtonClasses: function confirmButtonClasses() { return 'el-button--primary ' + this.confirmButtonClass; }, cancelButtonClasses: function cancelButtonClasses() { return '' + this.cancelButtonClass; } }, methods: { getSafeClose: function getSafeClose() { var _this = this; var currentId = this.uid; return function () { _this.$nextTick(function () { if (currentId === _this.uid) _this.doClose(); }); }; }, doClose: function doClose() { var _this2 = this; if (!this.visible) return; this.visible = false; this._closing = true; this.onClose && this.onClose(); messageBox.closeDialog(); // 解绑 if (this.lockScroll) { setTimeout(this.restoreBodyStyle, 200); } this.opened = false; this.doAfterClose(); setTimeout(function () { if (_this2.action) _this2.callback(_this2.action, _this2); }); }, handleWrapperClick: function handleWrapperClick() { if (this.closeOnClickModal) { this.handleAction(this.distinguishCancelAndClose ? 'close' : 'cancel'); } }, handleInputEnter: function handleInputEnter() { if (this.inputType !== 'textarea') { return this.handleAction('confirm'); } }, handleAction: function handleAction(action) { if (this.$type === 'prompt' && action === 'confirm' && !this.validate()) { return; } this.action = action; if (typeof this.beforeClose === 'function') { this.close = this.getSafeClose(); this.beforeClose(action, this, this.close); } else { this.doClose(); } }, validate: function validate() { if (this.$type === 'prompt') { var inputPattern = this.inputPattern; if (inputPattern && !inputPattern.test(this.inputValue || '')) { this.editorErrorMessage = this.inputErrorMessage || Object(lib_locale_["t"])('el.messagebox.error'); Object(dom_["addClass"])(this.getInputElement(), 'invalid'); return false; } var inputValidator = this.inputValidator; if (typeof inputValidator === 'function') { var validateResult = inputValidator(this.inputValue); if (validateResult === false) { this.editorErrorMessage = this.inputErrorMessage || Object(lib_locale_["t"])('el.messagebox.error'); Object(dom_["addClass"])(this.getInputElement(), 'invalid'); return false; } if (typeof validateResult === 'string') { this.editorErrorMessage = validateResult; Object(dom_["addClass"])(this.getInputElement(), 'invalid'); return false; } } } this.editorErrorMessage = ''; Object(dom_["removeClass"])(this.getInputElement(), 'invalid'); return true; }, getFirstFocus: function getFirstFocus() { var btn = this.$el.querySelector('.el-message-box__btns .el-button'); var title = this.$el.querySelector('.el-message-box__btns .el-message-box__title'); return btn || title; }, getInputElement: function getInputElement() { var inputRefs = this.$refs.input.$refs; return inputRefs.input || inputRefs.textarea; }, handleClose: function handleClose() { this.handleAction('close'); } }, watch: { inputValue: { immediate: true, handler: function handler(val) { var _this3 = this; this.$nextTick(function (_) { if (_this3.$type === 'prompt' && val !== null) { _this3.validate(); } }); } }, visible: function visible(val) { var _this4 = this; if (val) { this.uid++; if (this.$type === 'alert' || this.$type === 'confirm') { this.$nextTick(function () { _this4.$refs.confirm.$el.focus(); }); } this.focusAfterClosed = document.activeElement; messageBox = new aria_dialog_default.a(this.$el, this.focusAfterClosed, this.getFirstFocus()); } // prompt if (this.$type !== 'prompt') return; if (val) { setTimeout(function () { if (_this4.$refs.input && _this4.$refs.input.$el) { _this4.getInputElement().focus(); } }, 500); } else { this.editorErrorMessage = ''; Object(dom_["removeClass"])(this.getInputElement(), 'invalid'); } } }, mounted: function mounted() { var _this5 = this; this.$nextTick(function () { if (_this5.closeOnHashChange) { window.addEventListener('hashchange', _this5.close); } }); }, beforeDestroy: function beforeDestroy() { if (this.closeOnHashChange) { window.removeEventListener('hashchange', this.close); } setTimeout(function () { messageBox.closeDialog(); }); }, data: function data() { return { uid: 1, title: undefined, message: '', type: '', iconClass: '', customClass: '', showInput: false, inputValue: null, inputPlaceholder: '', inputType: 'text', inputPattern: null, inputValidator: null, inputErrorMessage: '', showConfirmButton: true, showCancelButton: false, action: '', confirmButtonText: '', cancelButtonText: '', confirmButtonLoading: false, cancelButtonLoading: false, confirmButtonClass: '', confirmButtonDisabled: false, cancelButtonClass: '', editorErrorMessage: null, callback: null, dangerouslyUseHTMLString: false, focusAfterClosed: null, isOnComposition: false, distinguishCancelAndClose: false }; } }); // CONCATENATED MODULE: ./packages/message-box/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_message_box_src_mainvue_type_script_lang_js_ = (message_box_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/message-box/src/main.vue /* normalize component */ var src_main_component = normalizeComponent( packages_message_box_src_mainvue_type_script_lang_js_, mainvue_type_template_id_6b29b012_render, mainvue_type_template_id_6b29b012_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var src_main_api; } src_main_component.options.__file = "packages/message-box/src/main.vue" /* harmony default export */ var message_box_src_main = (src_main_component.exports); // EXTERNAL MODULE: external "element-ui/lib/utils/vdom" var vdom_ = __webpack_require__(23); // CONCATENATED MODULE: ./packages/message-box/src/main.js var main_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; }; var main_defaults = { title: null, message: '', type: '', iconClass: '', showInput: false, showClose: true, modalFade: true, lockScroll: true, closeOnClickModal: true, closeOnPressEscape: true, closeOnHashChange: true, inputValue: null, inputPlaceholder: '', inputType: 'text', inputPattern: null, inputValidator: null, inputErrorMessage: '', showConfirmButton: true, showCancelButton: false, confirmButtonPosition: 'right', confirmButtonHighlight: false, cancelButtonHighlight: false, confirmButtonText: '', cancelButtonText: '', confirmButtonClass: '', cancelButtonClass: '', customClass: '', beforeClose: null, dangerouslyUseHTMLString: false, center: false, roundButton: false, distinguishCancelAndClose: false }; var MessageBoxConstructor = external_vue_default.a.extend(message_box_src_main); var currentMsg = void 0, main_instance = void 0; var msgQueue = []; var defaultCallback = function defaultCallback(action) { if (currentMsg) { var callback = currentMsg.callback; if (typeof callback === 'function') { if (main_instance.showInput) { callback(main_instance.inputValue, action); } else { callback(action); } } if (currentMsg.resolve) { if (action === 'confirm') { if (main_instance.showInput) { currentMsg.resolve({ value: main_instance.inputValue, action: action }); } else { currentMsg.resolve(action); } } else if (currentMsg.reject && (action === 'cancel' || action === 'close')) { currentMsg.reject(action); } } } }; var initInstance = function initInstance() { main_instance = new MessageBoxConstructor({ el: document.createElement('div') }); main_instance.callback = defaultCallback; }; var main_showNextMsg = function showNextMsg() { if (!main_instance) { initInstance(); } main_instance.action = ''; if (!main_instance.visible || main_instance.closeTimer) { if (msgQueue.length > 0) { currentMsg = msgQueue.shift(); var options = currentMsg.options; for (var prop in options) { if (options.hasOwnProperty(prop)) { main_instance[prop] = options[prop]; } } if (options.callback === undefined) { main_instance.callback = defaultCallback; } var oldCb = main_instance.callback; main_instance.callback = function (action, instance) { oldCb(action, instance); showNextMsg(); }; if (Object(vdom_["isVNode"])(main_instance.message)) { main_instance.$slots.default = [main_instance.message]; main_instance.message = null; } else { delete main_instance.$slots.default; } ['modal', 'showClose', 'closeOnClickModal', 'closeOnPressEscape', 'closeOnHashChange'].forEach(function (prop) { if (main_instance[prop] === undefined) { main_instance[prop] = true; } }); document.body.appendChild(main_instance.$el); external_vue_default.a.nextTick(function () { main_instance.visible = true; }); } } }; var main_MessageBox = function MessageBox(options, callback) { if (external_vue_default.a.prototype.$isServer) return; if (typeof options === 'string' || Object(vdom_["isVNode"])(options)) { options = { message: options }; if (typeof arguments[1] === 'string') { options.title = arguments[1]; } } else if (options.callback && !callback) { callback = options.callback; } if (typeof Promise !== 'undefined') { return new Promise(function (resolve, reject) { // eslint-disable-line msgQueue.push({ options: merge_default()({}, main_defaults, MessageBox.defaults, options), callback: callback, resolve: resolve, reject: reject }); main_showNextMsg(); }); } else { msgQueue.push({ options: merge_default()({}, main_defaults, MessageBox.defaults, options), callback: callback }); main_showNextMsg(); } }; main_MessageBox.setDefaults = function (defaults) { main_MessageBox.defaults = defaults; }; main_MessageBox.alert = function (message, title, options) { if ((typeof title === 'undefined' ? 'undefined' : main_typeof(title)) === 'object') { options = title; title = ''; } else if (title === undefined) { title = ''; } return main_MessageBox(merge_default()({ title: title, message: message, $type: 'alert', closeOnPressEscape: false, closeOnClickModal: false }, options)); }; main_MessageBox.confirm = function (message, title, options) { if ((typeof title === 'undefined' ? 'undefined' : main_typeof(title)) === 'object') { options = title; title = ''; } else if (title === undefined) { title = ''; } return main_MessageBox(merge_default()({ title: title, message: message, $type: 'confirm', showCancelButton: true }, options)); }; main_MessageBox.prompt = function (message, title, options) { if ((typeof title === 'undefined' ? 'undefined' : main_typeof(title)) === 'object') { options = title; title = ''; } else if (title === undefined) { title = ''; } return main_MessageBox(merge_default()({ title: title, message: message, showCancelButton: true, showInput: true, $type: 'prompt' }, options)); }; main_MessageBox.close = function () { main_instance.doClose(); main_instance.visible = false; msgQueue = []; currentMsg = null; }; /* harmony default export */ var packages_message_box_src_main = (main_MessageBox); // CONCATENATED MODULE: ./packages/message-box/index.js /* harmony default export */ var message_box = (packages_message_box_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb.vue?vue&type=template&id=4b464c06& var breadcrumbvue_type_template_id_4b464c06_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-breadcrumb", attrs: { "aria-label": "Breadcrumb", role: "navigation" } }, [_vm._t("default")], 2 ) } var breadcrumbvue_type_template_id_4b464c06_staticRenderFns = [] breadcrumbvue_type_template_id_4b464c06_render._withStripped = true // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb.vue?vue&type=template&id=4b464c06& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb.vue?vue&type=script&lang=js& // // // // // /* harmony default export */ var breadcrumbvue_type_script_lang_js_ = ({ name: 'ElBreadcrumb', props: { separator: { type: String, default: '/' }, separatorClass: { type: String, default: '' } }, provide: function provide() { return { elBreadcrumb: this }; }, mounted: function mounted() { var items = this.$el.querySelectorAll('.el-breadcrumb__item'); if (items.length) { items[items.length - 1].setAttribute('aria-current', 'page'); } } }); // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb.vue?vue&type=script&lang=js& /* harmony default export */ var src_breadcrumbvue_type_script_lang_js_ = (breadcrumbvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb.vue /* normalize component */ var breadcrumb_component = normalizeComponent( src_breadcrumbvue_type_script_lang_js_, breadcrumbvue_type_template_id_4b464c06_render, breadcrumbvue_type_template_id_4b464c06_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var breadcrumb_api; } breadcrumb_component.options.__file = "packages/breadcrumb/src/breadcrumb.vue" /* harmony default export */ var breadcrumb = (breadcrumb_component.exports); // CONCATENATED MODULE: ./packages/breadcrumb/index.js /* istanbul ignore next */ breadcrumb.install = function (Vue) { Vue.component(breadcrumb.name, breadcrumb); }; /* harmony default export */ var packages_breadcrumb = (breadcrumb); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=template&id=fcf9eaac& var breadcrumb_itemvue_type_template_id_fcf9eaac_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("span", { staticClass: "el-breadcrumb__item" }, [ _c( "span", { ref: "link", class: ["el-breadcrumb__inner", _vm.to ? "is-link" : ""], attrs: { role: "link" } }, [_vm._t("default")], 2 ), _vm.separatorClass ? _c("i", { staticClass: "el-breadcrumb__separator", class: _vm.separatorClass }) : _c( "span", { staticClass: "el-breadcrumb__separator", attrs: { role: "presentation" } }, [_vm._v(_vm._s(_vm.separator))] ) ]) } var breadcrumb_itemvue_type_template_id_fcf9eaac_staticRenderFns = [] breadcrumb_itemvue_type_template_id_fcf9eaac_render._withStripped = true // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=template&id=fcf9eaac& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=script&lang=js& // // // // // // // // // // // // /* harmony default export */ var breadcrumb_itemvue_type_script_lang_js_ = ({ name: 'ElBreadcrumbItem', props: { to: {}, replace: Boolean }, data: function data() { return { separator: '', separatorClass: '' }; }, inject: ['elBreadcrumb'], mounted: function mounted() { var _this = this; this.separator = this.elBreadcrumb.separator; this.separatorClass = this.elBreadcrumb.separatorClass; var link = this.$refs.link; link.setAttribute('role', 'link'); link.addEventListener('click', function (_) { var to = _this.to, $router = _this.$router; if (!to || !$router) return; _this.replace ? $router.replace(to) : $router.push(to); }); } }); // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb-item.vue?vue&type=script&lang=js& /* harmony default export */ var src_breadcrumb_itemvue_type_script_lang_js_ = (breadcrumb_itemvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/breadcrumb/src/breadcrumb-item.vue /* normalize component */ var breadcrumb_item_component = normalizeComponent( src_breadcrumb_itemvue_type_script_lang_js_, breadcrumb_itemvue_type_template_id_fcf9eaac_render, breadcrumb_itemvue_type_template_id_fcf9eaac_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var breadcrumb_item_api; } breadcrumb_item_component.options.__file = "packages/breadcrumb/src/breadcrumb-item.vue" /* harmony default export */ var breadcrumb_item = (breadcrumb_item_component.exports); // CONCATENATED MODULE: ./packages/breadcrumb-item/index.js /* istanbul ignore next */ breadcrumb_item.install = function (Vue) { Vue.component(breadcrumb_item.name, breadcrumb_item); }; /* harmony default export */ var packages_breadcrumb_item = (breadcrumb_item); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/form.vue?vue&type=template&id=a1b5ff34& var formvue_type_template_id_a1b5ff34_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "form", { staticClass: "el-form", class: [ _vm.labelPosition ? "el-form--label-" + _vm.labelPosition : "", { "el-form--inline": _vm.inline } ] }, [_vm._t("default")], 2 ) } var formvue_type_template_id_a1b5ff34_staticRenderFns = [] formvue_type_template_id_a1b5ff34_render._withStripped = true // CONCATENATED MODULE: ./packages/form/src/form.vue?vue&type=template&id=a1b5ff34& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/form.vue?vue&type=script&lang=js& // // // // // // // // /* harmony default export */ var formvue_type_script_lang_js_ = ({ name: 'ElForm', componentName: 'ElForm', provide: function provide() { return { elForm: this }; }, props: { model: Object, rules: Object, labelPosition: String, labelWidth: String, labelSuffix: { type: String, default: '' }, inline: Boolean, inlineMessage: Boolean, statusIcon: Boolean, showMessage: { type: Boolean, default: true }, size: String, disabled: Boolean, validateOnRuleChange: { type: Boolean, default: true }, hideRequiredAsterisk: { type: Boolean, default: false } }, watch: { rules: function rules() { // remove then add event listeners on form-item after form rules change this.fields.forEach(function (field) { field.removeValidateEvents(); field.addValidateEvents(); }); if (this.validateOnRuleChange) { this.validate(function () {}); } } }, computed: { autoLabelWidth: function autoLabelWidth() { if (!this.potentialLabelWidthArr.length) return 0; var max = Math.max.apply(Math, this.potentialLabelWidthArr); return max ? max + 'px' : ''; } }, data: function data() { return { fields: [], potentialLabelWidthArr: [] // use this array to calculate auto width }; }, created: function created() { var _this = this; this.$on('el.form.addField', function (field) { if (field) { _this.fields.push(field); } }); /* istanbul ignore next */ this.$on('el.form.removeField', function (field) { if (field.prop) { _this.fields.splice(_this.fields.indexOf(field), 1); } }); }, methods: { resetFields: function resetFields() { if (!this.model) { console.warn('[Element Warn][Form]model is required for resetFields to work.'); return; } this.fields.forEach(function (field) { field.resetField(); }); }, clearValidate: function clearValidate() { var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; var fields = props.length ? typeof props === 'string' ? this.fields.filter(function (field) { return props === field.prop; }) : this.fields.filter(function (field) { return props.indexOf(field.prop) > -1; }) : this.fields; fields.forEach(function (field) { field.clearValidate(); }); }, validate: function validate(callback) { var _this2 = this; if (!this.model) { console.warn('[Element Warn][Form]model is required for validate to work!'); return; } var promise = void 0; // if no callback, return promise if (typeof callback !== 'function' && window.Promise) { promise = new window.Promise(function (resolve, reject) { callback = function callback(valid) { valid ? resolve(valid) : reject(valid); }; }); } var valid = true; var count = 0; // 如果需要验证的fields为空,调用验证时立刻返回callback if (this.fields.length === 0 && callback) { callback(true); } var invalidFields = {}; this.fields.forEach(function (field) { field.validate('', function (message, field) { if (message) { valid = false; } invalidFields = merge_default()({}, invalidFields, field); if (typeof callback === 'function' && ++count === _this2.fields.length) { callback(valid, invalidFields); } }); }); if (promise) { return promise; } }, validateField: function validateField(props, cb) { props = [].concat(props); var fields = this.fields.filter(function (field) { return props.indexOf(field.prop) !== -1; }); if (!fields.length) { console.warn('[Element Warn]please pass correct props!'); return; } fields.forEach(function (field) { field.validate('', cb); }); }, getLabelWidthIndex: function getLabelWidthIndex(width) { var index = this.potentialLabelWidthArr.indexOf(width); // it's impossible if (index === -1) { throw new Error('[ElementForm]unpected width ', width); } return index; }, registerLabelWidth: function registerLabelWidth(val, oldVal) { if (val && oldVal) { var index = this.getLabelWidthIndex(oldVal); this.potentialLabelWidthArr.splice(index, 1, val); } else if (val) { this.potentialLabelWidthArr.push(val); } }, deregisterLabelWidth: function deregisterLabelWidth(val) { var index = this.getLabelWidthIndex(val); this.potentialLabelWidthArr.splice(index, 1); } } }); // CONCATENATED MODULE: ./packages/form/src/form.vue?vue&type=script&lang=js& /* harmony default export */ var src_formvue_type_script_lang_js_ = (formvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/form/src/form.vue /* normalize component */ var form_component = normalizeComponent( src_formvue_type_script_lang_js_, formvue_type_template_id_a1b5ff34_render, formvue_type_template_id_a1b5ff34_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var form_api; } form_component.options.__file = "packages/form/src/form.vue" /* harmony default export */ var src_form = (form_component.exports); // CONCATENATED MODULE: ./packages/form/index.js /* istanbul ignore next */ src_form.install = function (Vue) { Vue.component(src_form.name, src_form); }; /* harmony default export */ var packages_form = (src_form); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/form-item.vue?vue&type=template&id=b6f3db6c& var form_itemvue_type_template_id_b6f3db6c_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-form-item", class: [ { "el-form-item--feedback": _vm.elForm && _vm.elForm.statusIcon, "is-error": _vm.validateState === "error", "is-validating": _vm.validateState === "validating", "is-success": _vm.validateState === "success", "is-required": _vm.isRequired || _vm.required, "is-no-asterisk": _vm.elForm && _vm.elForm.hideRequiredAsterisk }, _vm.sizeClass ? "el-form-item--" + _vm.sizeClass : "" ] }, [ _c( "label-wrap", { attrs: { "is-auto-width": _vm.labelStyle && _vm.labelStyle.width === "auto", "update-all": _vm.form.labelWidth === "auto" } }, [ _vm.label || _vm.$slots.label ? _c( "label", { staticClass: "el-form-item__label", style: _vm.labelStyle, attrs: { for: _vm.labelFor } }, [ _vm._t("label", [ _vm._v(_vm._s(_vm.label + _vm.form.labelSuffix)) ]) ], 2 ) : _vm._e() ] ), _c( "div", { staticClass: "el-form-item__content", style: _vm.contentStyle }, [ _vm._t("default"), _c( "transition", { attrs: { name: "el-zoom-in-top" } }, [ _vm.validateState === "error" && _vm.showMessage && _vm.form.showMessage ? _vm._t( "error", [ _c( "div", { staticClass: "el-form-item__error", class: { "el-form-item__error--inline": typeof _vm.inlineMessage === "boolean" ? _vm.inlineMessage : (_vm.elForm && _vm.elForm.inlineMessage) || false } }, [ _vm._v( "\n " + _vm._s(_vm.validateMessage) + "\n " ) ] ) ], { error: _vm.validateMessage } ) : _vm._e() ], 2 ) ], 2 ) ], 1 ) } var form_itemvue_type_template_id_b6f3db6c_staticRenderFns = [] form_itemvue_type_template_id_b6f3db6c_render._withStripped = true // CONCATENATED MODULE: ./packages/form/src/form-item.vue?vue&type=template&id=b6f3db6c& // EXTERNAL MODULE: external "async-validator" var external_async_validator_ = __webpack_require__(40); var external_async_validator_default = /*#__PURE__*/__webpack_require__.n(external_async_validator_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/label-wrap.vue?vue&type=script&lang=js& /* harmony default export */ var label_wrapvue_type_script_lang_js_ = ({ props: { isAutoWidth: Boolean, updateAll: Boolean }, inject: ['elForm', 'elFormItem'], render: function render() { var h = arguments[0]; var slots = this.$slots.default; if (!slots) return null; if (this.isAutoWidth) { var autoLabelWidth = this.elForm.autoLabelWidth; var style = {}; if (autoLabelWidth && autoLabelWidth !== 'auto') { var marginLeft = parseInt(autoLabelWidth, 10) - this.computedWidth; if (marginLeft) { style.marginLeft = marginLeft + 'px'; } } return h( 'div', { 'class': 'el-form-item__label-wrap', style: style }, [slots] ); } else { return slots[0]; } }, methods: { getLabelWidth: function getLabelWidth() { if (this.$el && this.$el.firstElementChild) { var computedWidth = window.getComputedStyle(this.$el.firstElementChild).width; return Math.ceil(parseFloat(computedWidth)); } else { return 0; } }, updateLabelWidth: function updateLabelWidth() { var action = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'update'; if (this.$slots.default && this.isAutoWidth && this.$el.firstElementChild) { if (action === 'update') { this.computedWidth = this.getLabelWidth(); } else if (action === 'remove') { this.elForm.deregisterLabelWidth(this.computedWidth); } } } }, watch: { computedWidth: function computedWidth(val, oldVal) { if (this.updateAll) { this.elForm.registerLabelWidth(val, oldVal); this.elFormItem.updateComputedLabelWidth(val); } } }, data: function data() { return { computedWidth: 0 }; }, mounted: function mounted() { this.updateLabelWidth('update'); }, updated: function updated() { this.updateLabelWidth('update'); }, beforeDestroy: function beforeDestroy() { this.updateLabelWidth('remove'); } }); // CONCATENATED MODULE: ./packages/form/src/label-wrap.vue?vue&type=script&lang=js& /* harmony default export */ var src_label_wrapvue_type_script_lang_js_ = (label_wrapvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/form/src/label-wrap.vue var label_wrap_render, label_wrap_staticRenderFns /* normalize component */ var label_wrap_component = normalizeComponent( src_label_wrapvue_type_script_lang_js_, label_wrap_render, label_wrap_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var label_wrap_api; } label_wrap_component.options.__file = "packages/form/src/label-wrap.vue" /* harmony default export */ var label_wrap = (label_wrap_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/form-item.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var form_itemvue_type_script_lang_js_ = ({ name: 'ElFormItem', componentName: 'ElFormItem', mixins: [emitter_default.a], provide: function provide() { return { elFormItem: this }; }, inject: ['elForm'], props: { label: String, labelWidth: String, prop: String, required: { type: Boolean, default: undefined }, rules: [Object, Array], error: String, validateStatus: String, for: String, inlineMessage: { type: [String, Boolean], default: '' }, showMessage: { type: Boolean, default: true }, size: String }, components: { // use this component to calculate auto width LabelWrap: label_wrap }, watch: { error: { immediate: true, handler: function handler(value) { this.validateMessage = value; this.validateState = value ? 'error' : ''; } }, validateStatus: function validateStatus(value) { this.validateState = value; } }, computed: { labelFor: function labelFor() { return this.for || this.prop; }, labelStyle: function labelStyle() { var ret = {}; if (this.form.labelPosition === 'top') return ret; var labelWidth = this.labelWidth || this.form.labelWidth; if (labelWidth) { ret.width = labelWidth; } return ret; }, contentStyle: function contentStyle() { var ret = {}; var label = this.label; if (this.form.labelPosition === 'top' || this.form.inline) return ret; if (!label && !this.labelWidth && this.isNested) return ret; var labelWidth = this.labelWidth || this.form.labelWidth; if (labelWidth === 'auto') { if (this.labelWidth === 'auto') { ret.marginLeft = this.computedLabelWidth; } else if (this.form.labelWidth === 'auto') { ret.marginLeft = this.elForm.autoLabelWidth; } } else { ret.marginLeft = labelWidth; } return ret; }, form: function form() { var parent = this.$parent; var parentName = parent.$options.componentName; while (parentName !== 'ElForm') { if (parentName === 'ElFormItem') { this.isNested = true; } parent = parent.$parent; parentName = parent.$options.componentName; } return parent; }, fieldValue: function fieldValue() { var model = this.form.model; if (!model || !this.prop) { return; } var path = this.prop; if (path.indexOf(':') !== -1) { path = path.replace(/:/, '.'); } return Object(util_["getPropByPath"])(model, path, true).v; }, isRequired: function isRequired() { var rules = this.getRules(); var isRequired = false; if (rules && rules.length) { rules.every(function (rule) { if (rule.required) { isRequired = true; return false; } return true; }); } return isRequired; }, _formSize: function _formSize() { return this.elForm.size; }, elFormItemSize: function elFormItemSize() { return this.size || this._formSize; }, sizeClass: function sizeClass() { return this.elFormItemSize || (this.$ELEMENT || {}).size; } }, data: function data() { return { validateState: '', validateMessage: '', validateDisabled: false, validator: {}, isNested: false, computedLabelWidth: '' }; }, methods: { validate: function validate(trigger) { var _this = this; var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : util_["noop"]; this.validateDisabled = false; var rules = this.getFilteredRule(trigger); if ((!rules || rules.length === 0) && this.required === undefined) { callback(); return true; } this.validateState = 'validating'; var descriptor = {}; if (rules && rules.length > 0) { rules.forEach(function (rule) { delete rule.trigger; }); } descriptor[this.prop] = rules; var validator = new external_async_validator_default.a(descriptor); var model = {}; model[this.prop] = this.fieldValue; validator.validate(model, { firstFields: true }, function (errors, invalidFields) { _this.validateState = !errors ? 'success' : 'error'; _this.validateMessage = errors ? errors[0].message : ''; callback(_this.validateMessage, invalidFields); _this.elForm && _this.elForm.$emit('validate', _this.prop, !errors, _this.validateMessage || null); }); }, clearValidate: function clearValidate() { this.validateState = ''; this.validateMessage = ''; this.validateDisabled = false; }, resetField: function resetField() { var _this2 = this; this.validateState = ''; this.validateMessage = ''; var model = this.form.model; var value = this.fieldValue; var path = this.prop; if (path.indexOf(':') !== -1) { path = path.replace(/:/, '.'); } var prop = Object(util_["getPropByPath"])(model, path, true); this.validateDisabled = true; if (Array.isArray(value)) { prop.o[prop.k] = [].concat(this.initialValue); } else { prop.o[prop.k] = this.initialValue; } // reset validateDisabled after onFieldChange triggered this.$nextTick(function () { _this2.validateDisabled = false; }); this.broadcast('ElTimeSelect', 'fieldReset', this.initialValue); }, getRules: function getRules() { var formRules = this.form.rules; var selfRules = this.rules; var requiredRule = this.required !== undefined ? { required: !!this.required } : []; var prop = Object(util_["getPropByPath"])(formRules, this.prop || ''); formRules = formRules ? prop.o[this.prop || ''] || prop.v : []; return [].concat(selfRules || formRules || []).concat(requiredRule); }, getFilteredRule: function getFilteredRule(trigger) { var rules = this.getRules(); return rules.filter(function (rule) { if (!rule.trigger || trigger === '') return true; if (Array.isArray(rule.trigger)) { return rule.trigger.indexOf(trigger) > -1; } else { return rule.trigger === trigger; } }).map(function (rule) { return merge_default()({}, rule); }); }, onFieldBlur: function onFieldBlur() { this.validate('blur'); }, onFieldChange: function onFieldChange() { if (this.validateDisabled) { this.validateDisabled = false; return; } this.validate('change'); }, updateComputedLabelWidth: function updateComputedLabelWidth(width) { this.computedLabelWidth = width ? width + 'px' : ''; }, addValidateEvents: function addValidateEvents() { var rules = this.getRules(); if (rules.length || this.required !== undefined) { this.$on('el.form.blur', this.onFieldBlur); this.$on('el.form.change', this.onFieldChange); } }, removeValidateEvents: function removeValidateEvents() { this.$off(); } }, mounted: function mounted() { if (this.prop) { this.dispatch('ElForm', 'el.form.addField', [this]); var initialValue = this.fieldValue; if (Array.isArray(initialValue)) { initialValue = [].concat(initialValue); } Object.defineProperty(this, 'initialValue', { value: initialValue }); this.addValidateEvents(); } }, beforeDestroy: function beforeDestroy() { this.dispatch('ElForm', 'el.form.removeField', [this]); } }); // CONCATENATED MODULE: ./packages/form/src/form-item.vue?vue&type=script&lang=js& /* harmony default export */ var src_form_itemvue_type_script_lang_js_ = (form_itemvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/form/src/form-item.vue /* normalize component */ var form_item_component = normalizeComponent( src_form_itemvue_type_script_lang_js_, form_itemvue_type_template_id_b6f3db6c_render, form_itemvue_type_template_id_b6f3db6c_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var form_item_api; } form_item_component.options.__file = "packages/form/src/form-item.vue" /* harmony default export */ var form_item = (form_item_component.exports); // CONCATENATED MODULE: ./packages/form-item/index.js /* istanbul ignore next */ form_item.install = function (Vue) { Vue.component(form_item.name, form_item); }; /* harmony default export */ var packages_form_item = (form_item); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-bar.vue?vue&type=template&id=2031f33a& var tab_barvue_type_template_id_2031f33a_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("div", { staticClass: "el-tabs__active-bar", class: "is-" + _vm.rootTabs.tabPosition, style: _vm.barStyle }) } var tab_barvue_type_template_id_2031f33a_staticRenderFns = [] tab_barvue_type_template_id_2031f33a_render._withStripped = true // CONCATENATED MODULE: ./packages/tabs/src/tab-bar.vue?vue&type=template&id=2031f33a& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-bar.vue?vue&type=script&lang=js& // // // /* harmony default export */ var tab_barvue_type_script_lang_js_ = ({ name: 'TabBar', props: { tabs: Array }, inject: ['rootTabs'], computed: { barStyle: { get: function get() { var _this = this; var style = {}; var offset = 0; var tabSize = 0; var sizeName = ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'width' : 'height'; var sizeDir = sizeName === 'width' ? 'x' : 'y'; var firstUpperCase = function firstUpperCase(str) { return str.toLowerCase().replace(/( |^)[a-z]/g, function (L) { return L.toUpperCase(); }); }; this.tabs.every(function (tab, index) { var $el = Object(util_["arrayFind"])(_this.$parent.$refs.tabs || [], function (t) { return t.id.replace('tab-', '') === tab.paneName; }); if (!$el) { return false; } if (!tab.active) { offset += $el['client' + firstUpperCase(sizeName)]; return true; } else { tabSize = $el['client' + firstUpperCase(sizeName)]; var tabStyles = window.getComputedStyle($el); if (sizeName === 'width' && _this.tabs.length > 1) { tabSize -= parseFloat(tabStyles.paddingLeft) + parseFloat(tabStyles.paddingRight); } if (sizeName === 'width') { offset += parseFloat(tabStyles.paddingLeft); } return false; } }); var transform = 'translate' + firstUpperCase(sizeDir) + '(' + offset + 'px)'; style[sizeName] = tabSize + 'px'; style.transform = transform; style.msTransform = transform; style.webkitTransform = transform; return style; } } } }); // CONCATENATED MODULE: ./packages/tabs/src/tab-bar.vue?vue&type=script&lang=js& /* harmony default export */ var src_tab_barvue_type_script_lang_js_ = (tab_barvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/tabs/src/tab-bar.vue /* normalize component */ var tab_bar_component = normalizeComponent( src_tab_barvue_type_script_lang_js_, tab_barvue_type_template_id_2031f33a_render, tab_barvue_type_template_id_2031f33a_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var tab_bar_api; } tab_bar_component.options.__file = "packages/tabs/src/tab-bar.vue" /* harmony default export */ var tab_bar = (tab_bar_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-nav.vue?vue&type=script&lang=js& function noop() {} var tab_navvue_type_script_lang_js_firstUpperCase = function firstUpperCase(str) { return str.toLowerCase().replace(/( |^)[a-z]/g, function (L) { return L.toUpperCase(); }); }; /* harmony default export */ var tab_navvue_type_script_lang_js_ = ({ name: 'TabNav', components: { TabBar: tab_bar }, inject: ['rootTabs'], props: { panes: Array, currentName: String, editable: Boolean, onTabClick: { type: Function, default: noop }, onTabRemove: { type: Function, default: noop }, type: String, stretch: Boolean }, data: function data() { return { scrollable: false, navOffset: 0, isFocus: false, focusable: true }; }, computed: { navStyle: function navStyle() { var dir = ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'X' : 'Y'; return { transform: 'translate' + dir + '(-' + this.navOffset + 'px)' }; }, sizeName: function sizeName() { return ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'width' : 'height'; } }, methods: { scrollPrev: function scrollPrev() { var containerSize = this.$refs.navScroll['offset' + tab_navvue_type_script_lang_js_firstUpperCase(this.sizeName)]; var currentOffset = this.navOffset; if (!currentOffset) return; var newOffset = currentOffset > containerSize ? currentOffset - containerSize : 0; this.navOffset = newOffset; }, scrollNext: function scrollNext() { var navSize = this.$refs.nav['offset' + tab_navvue_type_script_lang_js_firstUpperCase(this.sizeName)]; var containerSize = this.$refs.navScroll['offset' + tab_navvue_type_script_lang_js_firstUpperCase(this.sizeName)]; var currentOffset = this.navOffset; if (navSize - currentOffset <= containerSize) return; var newOffset = navSize - currentOffset > containerSize * 2 ? currentOffset + containerSize : navSize - containerSize; this.navOffset = newOffset; }, scrollToActiveTab: function scrollToActiveTab() { if (!this.scrollable) return; var nav = this.$refs.nav; var activeTab = this.$el.querySelector('.is-active'); if (!activeTab) return; var navScroll = this.$refs.navScroll; var isHorizontal = ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1; var activeTabBounding = activeTab.getBoundingClientRect(); var navScrollBounding = navScroll.getBoundingClientRect(); var maxOffset = isHorizontal ? nav.offsetWidth - navScrollBounding.width : nav.offsetHeight - navScrollBounding.height; var currentOffset = this.navOffset; var newOffset = currentOffset; if (isHorizontal) { if (activeTabBounding.left < navScrollBounding.left) { newOffset = currentOffset - (navScrollBounding.left - activeTabBounding.left); } if (activeTabBounding.right > navScrollBounding.right) { newOffset = currentOffset + activeTabBounding.right - navScrollBounding.right; } } else { if (activeTabBounding.top < navScrollBounding.top) { newOffset = currentOffset - (navScrollBounding.top - activeTabBounding.top); } if (activeTabBounding.bottom > navScrollBounding.bottom) { newOffset = currentOffset + (activeTabBounding.bottom - navScrollBounding.bottom); } } newOffset = Math.max(newOffset, 0); this.navOffset = Math.min(newOffset, maxOffset); }, update: function update() { if (!this.$refs.nav) return; var sizeName = this.sizeName; var navSize = this.$refs.nav['offset' + tab_navvue_type_script_lang_js_firstUpperCase(sizeName)]; var containerSize = this.$refs.navScroll['offset' + tab_navvue_type_script_lang_js_firstUpperCase(sizeName)]; var currentOffset = this.navOffset; if (containerSize < navSize) { var _currentOffset = this.navOffset; this.scrollable = this.scrollable || {}; this.scrollable.prev = _currentOffset; this.scrollable.next = _currentOffset + containerSize < navSize; if (navSize - _currentOffset < containerSize) { this.navOffset = navSize - containerSize; } } else { this.scrollable = false; if (currentOffset > 0) { this.navOffset = 0; } } }, changeTab: function changeTab(e) { var keyCode = e.keyCode; var nextIndex = void 0; var currentIndex = void 0, tabList = void 0; if ([37, 38, 39, 40].indexOf(keyCode) !== -1) { // 左右上下键更换tab tabList = e.currentTarget.querySelectorAll('[role=tab]'); currentIndex = Array.prototype.indexOf.call(tabList, e.target); } else { return; } if (keyCode === 37 || keyCode === 38) { // left if (currentIndex === 0) { // first nextIndex = tabList.length - 1; } else { nextIndex = currentIndex - 1; } } else { // right if (currentIndex < tabList.length - 1) { // not last nextIndex = currentIndex + 1; } else { nextIndex = 0; } } tabList[nextIndex].focus(); // 改变焦点元素 tabList[nextIndex].click(); // 选中下一个tab this.setFocus(); }, setFocus: function setFocus() { if (this.focusable) { this.isFocus = true; } }, removeFocus: function removeFocus() { this.isFocus = false; }, visibilityChangeHandler: function visibilityChangeHandler() { var _this = this; var visibility = document.visibilityState; if (visibility === 'hidden') { this.focusable = false; } else if (visibility === 'visible') { setTimeout(function () { _this.focusable = true; }, 50); } }, windowBlurHandler: function windowBlurHandler() { this.focusable = false; }, windowFocusHandler: function windowFocusHandler() { var _this2 = this; setTimeout(function () { _this2.focusable = true; }, 50); } }, updated: function updated() { this.update(); }, render: function render(h) { var _this3 = this; var type = this.type, panes = this.panes, editable = this.editable, stretch = this.stretch, onTabClick = this.onTabClick, onTabRemove = this.onTabRemove, navStyle = this.navStyle, scrollable = this.scrollable, scrollNext = this.scrollNext, scrollPrev = this.scrollPrev, changeTab = this.changeTab, setFocus = this.setFocus, removeFocus = this.removeFocus; var scrollBtn = scrollable ? [h( 'span', { 'class': ['el-tabs__nav-prev', scrollable.prev ? '' : 'is-disabled'], on: { 'click': scrollPrev } }, [h('i', { 'class': 'el-icon-arrow-left' })] ), h( 'span', { 'class': ['el-tabs__nav-next', scrollable.next ? '' : 'is-disabled'], on: { 'click': scrollNext } }, [h('i', { 'class': 'el-icon-arrow-right' })] )] : null; var tabs = this._l(panes, function (pane, index) { var _ref; var tabName = pane.name || pane.index || index; var closable = pane.isClosable || editable; pane.index = '' + index; var btnClose = closable ? h('span', { 'class': 'el-icon-close', on: { 'click': function click(ev) { onTabRemove(pane, ev); } } }) : null; var tabLabelContent = pane.$slots.label || pane.label; var tabindex = pane.active ? 0 : -1; return h( 'div', { 'class': (_ref = { 'el-tabs__item': true }, _ref['is-' + _this3.rootTabs.tabPosition] = true, _ref['is-active'] = pane.active, _ref['is-disabled'] = pane.disabled, _ref['is-closable'] = closable, _ref['is-focus'] = _this3.isFocus, _ref), attrs: { id: 'tab-' + tabName, 'aria-controls': 'pane-' + tabName, role: 'tab', 'aria-selected': pane.active, tabindex: tabindex }, key: 'tab-' + tabName, ref: 'tabs', refInFor: true, on: { 'focus': function focus() { setFocus(); }, 'blur': function blur() { removeFocus(); }, 'click': function click(ev) { removeFocus();onTabClick(pane, tabName, ev); }, 'keydown': function keydown(ev) { if (closable && (ev.keyCode === 46 || ev.keyCode === 8)) { onTabRemove(pane, ev); } } } }, [tabLabelContent, btnClose] ); }); return h( 'div', { 'class': ['el-tabs__nav-wrap', scrollable ? 'is-scrollable' : '', 'is-' + this.rootTabs.tabPosition] }, [scrollBtn, h( 'div', { 'class': ['el-tabs__nav-scroll'], ref: 'navScroll' }, [h( 'div', { 'class': ['el-tabs__nav', 'is-' + this.rootTabs.tabPosition, stretch && ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'is-stretch' : ''], ref: 'nav', style: navStyle, attrs: { role: 'tablist' }, on: { 'keydown': changeTab } }, [!type ? h('tab-bar', { attrs: { tabs: panes } }) : null, tabs] )] )] ); }, mounted: function mounted() { var _this4 = this; Object(resize_event_["addResizeListener"])(this.$el, this.update); document.addEventListener('visibilitychange', this.visibilityChangeHandler); window.addEventListener('blur', this.windowBlurHandler); window.addEventListener('focus', this.windowFocusHandler); setTimeout(function () { _this4.scrollToActiveTab(); }, 0); }, beforeDestroy: function beforeDestroy() { if (this.$el && this.update) Object(resize_event_["removeResizeListener"])(this.$el, this.update); document.removeEventListener('visibilitychange', this.visibilityChangeHandler); window.removeEventListener('blur', this.windowBlurHandler); window.removeEventListener('focus', this.windowFocusHandler); } }); // CONCATENATED MODULE: ./packages/tabs/src/tab-nav.vue?vue&type=script&lang=js& /* harmony default export */ var src_tab_navvue_type_script_lang_js_ = (tab_navvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/tabs/src/tab-nav.vue var tab_nav_render, tab_nav_staticRenderFns /* normalize component */ var tab_nav_component = normalizeComponent( src_tab_navvue_type_script_lang_js_, tab_nav_render, tab_nav_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var tab_nav_api; } tab_nav_component.options.__file = "packages/tabs/src/tab-nav.vue" /* harmony default export */ var tab_nav = (tab_nav_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tabs.vue?vue&type=script&lang=js& /* harmony default export */ var tabsvue_type_script_lang_js_ = ({ name: 'ElTabs', components: { TabNav: tab_nav }, props: { type: String, activeName: String, closable: Boolean, addable: Boolean, value: {}, editable: Boolean, tabPosition: { type: String, default: 'top' }, beforeLeave: Function, stretch: Boolean }, provide: function provide() { return { rootTabs: this }; }, data: function data() { return { currentName: this.value || this.activeName, panes: [] }; }, watch: { activeName: function activeName(value) { this.setCurrentName(value); }, value: function value(_value) { this.setCurrentName(_value); }, currentName: function currentName(value) { var _this = this; if (this.$refs.nav) { this.$nextTick(function () { _this.$refs.nav.$nextTick(function (_) { _this.$refs.nav.scrollToActiveTab(); }); }); } } }, methods: { calcPaneInstances: function calcPaneInstances() { var _this2 = this; var isForceUpdate = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; if (this.$slots.default) { var paneSlots = this.$slots.default.filter(function (vnode) { return vnode.tag && vnode.componentOptions && vnode.componentOptions.Ctor.options.name === 'ElTabPane'; }); // update indeed var panes = paneSlots.map(function (_ref) { var componentInstance = _ref.componentInstance; return componentInstance; }); var panesChanged = !(panes.length === this.panes.length && panes.every(function (pane, index) { return pane === _this2.panes[index]; })); if (isForceUpdate || panesChanged) { this.panes = panes; } } else if (this.panes.length !== 0) { this.panes = []; } }, handleTabClick: function handleTabClick(tab, tabName, event) { if (tab.disabled) return; this.setCurrentName(tabName); this.$emit('tab-click', tab, event); }, handleTabRemove: function handleTabRemove(pane, ev) { if (pane.disabled) return; ev.stopPropagation(); this.$emit('edit', pane.name, 'remove'); this.$emit('tab-remove', pane.name); }, handleTabAdd: function handleTabAdd() { this.$emit('edit', null, 'add'); this.$emit('tab-add'); }, setCurrentName: function setCurrentName(value) { var _this3 = this; var changeCurrentName = function changeCurrentName() { _this3.currentName = value; _this3.$emit('input', value); }; if (this.currentName !== value && this.beforeLeave) { var before = this.beforeLeave(value, this.currentName); if (before && before.then) { before.then(function () { changeCurrentName(); _this3.$refs.nav && _this3.$refs.nav.removeFocus(); }, function () { // https://github.com/ElemeFE/element/pull/14816 // ignore promise rejection in `before-leave` hook }); } else if (before !== false) { changeCurrentName(); } } else { changeCurrentName(); } } }, render: function render(h) { var _ref2; var type = this.type, handleTabClick = this.handleTabClick, handleTabRemove = this.handleTabRemove, handleTabAdd = this.handleTabAdd, currentName = this.currentName, panes = this.panes, editable = this.editable, addable = this.addable, tabPosition = this.tabPosition, stretch = this.stretch; var newButton = editable || addable ? h( 'span', { 'class': 'el-tabs__new-tab', on: { 'click': handleTabAdd, 'keydown': function keydown(ev) { if (ev.keyCode === 13) { handleTabAdd(); } } }, attrs: { tabindex: '0' } }, [h('i', { 'class': 'el-icon-plus' })] ) : null; var navData = { props: { currentName: currentName, onTabClick: handleTabClick, onTabRemove: handleTabRemove, editable: editable, type: type, panes: panes, stretch: stretch }, ref: 'nav' }; var header = h( 'div', { 'class': ['el-tabs__header', 'is-' + tabPosition] }, [newButton, h('tab-nav', navData)] ); var panels = h( 'div', { 'class': 'el-tabs__content' }, [this.$slots.default] ); return h( 'div', { 'class': (_ref2 = { 'el-tabs': true, 'el-tabs--card': type === 'card' }, _ref2['el-tabs--' + tabPosition] = true, _ref2['el-tabs--border-card'] = type === 'border-card', _ref2) }, [tabPosition !== 'bottom' ? [header, panels] : [panels, header]] ); }, created: function created() { if (!this.currentName) { this.setCurrentName('0'); } this.$on('tab-nav-update', this.calcPaneInstances.bind(null, true)); }, mounted: function mounted() { this.calcPaneInstances(); }, updated: function updated() { this.calcPaneInstances(); } }); // CONCATENATED MODULE: ./packages/tabs/src/tabs.vue?vue&type=script&lang=js& /* harmony default export */ var src_tabsvue_type_script_lang_js_ = (tabsvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/tabs/src/tabs.vue var tabs_render, tabs_staticRenderFns /* normalize component */ var tabs_component = normalizeComponent( src_tabsvue_type_script_lang_js_, tabs_render, tabs_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var tabs_api; } tabs_component.options.__file = "packages/tabs/src/tabs.vue" /* harmony default export */ var tabs = (tabs_component.exports); // CONCATENATED MODULE: ./packages/tabs/index.js /* istanbul ignore next */ tabs.install = function (Vue) { Vue.component(tabs.name, tabs); }; /* harmony default export */ var packages_tabs = (tabs); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-pane.vue?vue&type=template&id=9145a070& var tab_panevue_type_template_id_9145a070_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return !_vm.lazy || _vm.loaded || _vm.active ? _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.active, expression: "active" } ], staticClass: "el-tab-pane", attrs: { role: "tabpanel", "aria-hidden": !_vm.active, id: "pane-" + _vm.paneName, "aria-labelledby": "tab-" + _vm.paneName } }, [_vm._t("default")], 2 ) : _vm._e() } var tab_panevue_type_template_id_9145a070_staticRenderFns = [] tab_panevue_type_template_id_9145a070_render._withStripped = true // CONCATENATED MODULE: ./packages/tabs/src/tab-pane.vue?vue&type=template&id=9145a070& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-pane.vue?vue&type=script&lang=js& // // // // // // // // // // // // // /* harmony default export */ var tab_panevue_type_script_lang_js_ = ({ name: 'ElTabPane', componentName: 'ElTabPane', props: { label: String, labelContent: Function, name: String, closable: Boolean, disabled: Boolean, lazy: Boolean }, data: function data() { return { index: null, loaded: false }; }, computed: { isClosable: function isClosable() { return this.closable || this.$parent.closable; }, active: function active() { var active = this.$parent.currentName === (this.name || this.index); if (active) { this.loaded = true; } return active; }, paneName: function paneName() { return this.name || this.index; } }, updated: function updated() { this.$parent.$emit('tab-nav-update'); } }); // CONCATENATED MODULE: ./packages/tabs/src/tab-pane.vue?vue&type=script&lang=js& /* harmony default export */ var src_tab_panevue_type_script_lang_js_ = (tab_panevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/tabs/src/tab-pane.vue /* normalize component */ var tab_pane_component = normalizeComponent( src_tab_panevue_type_script_lang_js_, tab_panevue_type_template_id_9145a070_render, tab_panevue_type_template_id_9145a070_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var tab_pane_api; } tab_pane_component.options.__file = "packages/tabs/src/tab-pane.vue" /* harmony default export */ var tab_pane = (tab_pane_component.exports); // CONCATENATED MODULE: ./packages/tab-pane/index.js /* istanbul ignore next */ tab_pane.install = function (Vue) { Vue.component(tab_pane.name, tab_pane); }; /* harmony default export */ var packages_tab_pane = (tab_pane); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tag/src/tag.vue?vue&type=script&lang=js& /* harmony default export */ var tagvue_type_script_lang_js_ = ({ name: 'ElTag', props: { text: String, closable: Boolean, type: String, hit: Boolean, disableTransitions: Boolean, color: String, size: String, effect: { type: String, default: 'light', validator: function validator(val) { return ['dark', 'light', 'plain'].indexOf(val) !== -1; } } }, methods: { handleClose: function handleClose(event) { event.stopPropagation(); this.$emit('close', event); }, handleClick: function handleClick(event) { this.$emit('click', event); } }, computed: { tagSize: function tagSize() { return this.size || (this.$ELEMENT || {}).size; } }, render: function render(h) { var type = this.type, tagSize = this.tagSize, hit = this.hit, effect = this.effect; var classes = ['el-tag', type ? 'el-tag--' + type : '', tagSize ? 'el-tag--' + tagSize : '', effect ? 'el-tag--' + effect : '', hit && 'is-hit']; var tagEl = h( 'span', { 'class': classes, style: { backgroundColor: this.color }, on: { 'click': this.handleClick } }, [this.$slots.default, this.closable && h('i', { 'class': 'el-tag__close el-icon-close', on: { 'click': this.handleClose } })] ); return this.disableTransitions ? tagEl : h( 'transition', { attrs: { name: 'el-zoom-in-center' } }, [tagEl] ); } }); // CONCATENATED MODULE: ./packages/tag/src/tag.vue?vue&type=script&lang=js& /* harmony default export */ var src_tagvue_type_script_lang_js_ = (tagvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/tag/src/tag.vue var tag_render, tag_staticRenderFns /* normalize component */ var tag_component = normalizeComponent( src_tagvue_type_script_lang_js_, tag_render, tag_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var tag_api; } tag_component.options.__file = "packages/tag/src/tag.vue" /* harmony default export */ var tag = (tag_component.exports); // CONCATENATED MODULE: ./packages/tag/index.js /* istanbul ignore next */ tag.install = function (Vue) { Vue.component(tag.name, tag); }; /* harmony default export */ var packages_tag = (tag); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/tree/src/tree.vue?vue&type=template&id=547575a6& var treevue_type_template_id_547575a6_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-tree", class: { "el-tree--highlight-current": _vm.highlightCurrent, "is-dragging": !!_vm.dragState.draggingNode, "is-drop-not-allow": !_vm.dragState.allowDrop, "is-drop-inner": _vm.dragState.dropType === "inner" }, attrs: { role: "tree" } }, [ _vm._l(_vm.root.childNodes, function(child) { return _c("el-tree-node", { key: _vm.getNodeKey(child), attrs: { node: child, props: _vm.props, "render-after-expand": _vm.renderAfterExpand, "show-checkbox": _vm.showCheckbox, "render-content": _vm.renderContent }, on: { "node-expand": _vm.handleNodeExpand } }) }), _vm.isEmpty ? _c("div", { staticClass: "el-tree__empty-block" }, [ _c("span", { staticClass: "el-tree__empty-text" }, [ _vm._v(_vm._s(_vm.emptyText)) ]) ]) : _vm._e(), _c("div", { directives: [ { name: "show", rawName: "v-show", value: _vm.dragState.showDropIndicator, expression: "dragState.showDropIndicator" } ], ref: "dropIndicator", staticClass: "el-tree__drop-indicator" }) ], 2 ) } var treevue_type_template_id_547575a6_staticRenderFns = [] treevue_type_template_id_547575a6_render._withStripped = true // CONCATENATED MODULE: ./packages/tree/src/tree.vue?vue&type=template&id=547575a6& // CONCATENATED MODULE: ./packages/tree/src/model/util.js var NODE_KEY = '$treeNodeId'; var markNodeData = function markNodeData(node, data) { if (!data || data[NODE_KEY]) return; Object.defineProperty(data, NODE_KEY, { value: node.id, enumerable: false, configurable: false, writable: false }); }; var util_getNodeKey = function getNodeKey(key, data) { if (!key) return data[NODE_KEY]; return data[key]; }; var findNearestComponent = function findNearestComponent(element, componentName) { var target = element; while (target && target.tagName !== 'BODY') { if (target.__vue__ && target.__vue__.$options.name === componentName) { return target.__vue__; } target = target.parentNode; } return null; }; // CONCATENATED MODULE: ./packages/tree/src/model/node.js var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); function node_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var getChildState = function getChildState(node) { var all = true; var none = true; var allWithoutDisable = true; for (var i = 0, j = node.length; i < j; i++) { var n = node[i]; if (n.checked !== true || n.indeterminate) { all = false; if (!n.disabled) { allWithoutDisable = false; } } if (n.checked !== false || n.indeterminate) { none = false; } } return { all: all, none: none, allWithoutDisable: allWithoutDisable, half: !all && !none }; }; var reInitChecked = function reInitChecked(node) { if (node.childNodes.length === 0) return; var _getChildState = getChildState(node.childNodes), all = _getChildState.all, none = _getChildState.none, half = _getChildState.half; if (all) { node.checked = true; node.indeterminate = false; } else if (half) { node.checked = false; node.indeterminate = true; } else if (none) { node.checked = false; node.indeterminate = false; } var parent = node.parent; if (!parent || parent.level === 0) return; if (!node.store.checkStrictly) { reInitChecked(parent); } }; var getPropertyFromData = function getPropertyFromData(node, prop) { var props = node.store.props; var data = node.data || {}; var config = props[prop]; if (typeof config === 'function') { return config(data, node); } else if (typeof config === 'string') { return data[config]; } else if (typeof config === 'undefined') { var dataProp = data[prop]; return dataProp === undefined ? '' : dataProp; } }; var nodeIdSeed = 0; var node_Node = function () { function Node(options) { node_classCallCheck(this, Node); this.id = nodeIdSeed++; this.text = null; this.checked = false; this.indeterminate = false; this.data = null; this.expanded = false; this.parent = null; this.visible = true; this.isCurrent = false; for (var name in options) { if (options.hasOwnProperty(name)) { this[name] = options[name]; } } // internal this.level = 0; this.loaded = false; this.childNodes = []; this.loading = false; if (this.parent) { this.level = this.parent.level + 1; } var store = this.store; if (!store) { throw new Error('[Node]store is required!'); } store.registerNode(this); var props = store.props; if (props && typeof props.isLeaf !== 'undefined') { var isLeaf = getPropertyFromData(this, 'isLeaf'); if (typeof isLeaf === 'boolean') { this.isLeafByUser = isLeaf; } } if (store.lazy !== true && this.data) { this.setData(this.data); if (store.defaultExpandAll) { this.expanded = true; } } else if (this.level > 0 && store.lazy && store.defaultExpandAll) { this.expand(); } if (!Array.isArray(this.data)) { markNodeData(this, this.data); } if (!this.data) return; var defaultExpandedKeys = store.defaultExpandedKeys; var key = store.key; if (key && defaultExpandedKeys && defaultExpandedKeys.indexOf(this.key) !== -1) { this.expand(null, store.autoExpandParent); } if (key && store.currentNodeKey !== undefined && this.key === store.currentNodeKey) { store.currentNode = this; store.currentNode.isCurrent = true; } if (store.lazy) { store._initDefaultCheckedNode(this); } this.updateLeafState(); } Node.prototype.setData = function setData(data) { if (!Array.isArray(data)) { markNodeData(this, data); } this.data = data; this.childNodes = []; var children = void 0; if (this.level === 0 && this.data instanceof Array) { children = this.data; } else { children = getPropertyFromData(this, 'children') || []; } for (var i = 0, j = children.length; i < j; i++) { this.insertChild({ data: children[i] }); } }; Node.prototype.contains = function contains(target) { var deep = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; var walk = function walk(parent) { var children = parent.childNodes || []; var result = false; for (var i = 0, j = children.length; i < j; i++) { var child = children[i]; if (child === target || deep && walk(child)) { result = true; break; } } return result; }; return walk(this); }; Node.prototype.remove = function remove() { var parent = this.parent; if (parent) { parent.removeChild(this); } }; Node.prototype.insertChild = function insertChild(child, index, batch) { if (!child) throw new Error('insertChild error: child is required.'); if (!(child instanceof Node)) { if (!batch) { var children = this.getChildren(true); if (children.indexOf(child.data) === -1) { if (typeof index === 'undefined' || index < 0) { children.push(child.data); } else { children.splice(index, 0, child.data); } } } merge_default()(child, { parent: this, store: this.store }); child = new Node(child); } child.level = this.level + 1; if (typeof index === 'undefined' || index < 0) { this.childNodes.push(child); } else { this.childNodes.splice(index, 0, child); } this.updateLeafState(); }; Node.prototype.insertBefore = function insertBefore(child, ref) { var index = void 0; if (ref) { index = this.childNodes.indexOf(ref); } this.insertChild(child, index); }; Node.prototype.insertAfter = function insertAfter(child, ref) { var index = void 0; if (ref) { index = this.childNodes.indexOf(ref); if (index !== -1) index += 1; } this.insertChild(child, index); }; Node.prototype.removeChild = function removeChild(child) { var children = this.getChildren() || []; var dataIndex = children.indexOf(child.data); if (dataIndex > -1) { children.splice(dataIndex, 1); } var index = this.childNodes.indexOf(child); if (index > -1) { this.store && this.store.deregisterNode(child); child.parent = null; this.childNodes.splice(index, 1); } this.updateLeafState(); }; Node.prototype.removeChildByData = function removeChildByData(data) { var targetNode = null; for (var i = 0; i < this.childNodes.length; i++) { if (this.childNodes[i].data === data) { targetNode = this.childNodes[i]; break; } } if (targetNode) { this.removeChild(targetNode); } }; Node.prototype.expand = function expand(callback, expandParent) { var _this = this; var done = function done() { if (expandParent) { var parent = _this.parent; while (parent.level > 0) { parent.expanded = true; parent = parent.parent; } } _this.expanded = true; if (callback) callback(); }; if (this.shouldLoadData()) { this.loadData(function (data) { if (data instanceof Array) { if (_this.checked) { _this.setChecked(true, true); } else if (!_this.store.checkStrictly) { reInitChecked(_this); } done(); } }); } else { done(); } }; Node.prototype.doCreateChildren = function doCreateChildren(array) { var _this2 = this; var defaultProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; array.forEach(function (item) { _this2.insertChild(merge_default()({ data: item }, defaultProps), undefined, true); }); }; Node.prototype.collapse = function collapse() { this.expanded = false; }; Node.prototype.shouldLoadData = function shouldLoadData() { return this.store.lazy === true && this.store.load && !this.loaded; }; Node.prototype.updateLeafState = function updateLeafState() { if (this.store.lazy === true && this.loaded !== true && typeof this.isLeafByUser !== 'undefined') { this.isLeaf = this.isLeafByUser; return; } var childNodes = this.childNodes; if (!this.store.lazy || this.store.lazy === true && this.loaded === true) { this.isLeaf = !childNodes || childNodes.length === 0; return; } this.isLeaf = false; }; Node.prototype.setChecked = function setChecked(value, deep, recursion, passValue) { var _this3 = this; this.indeterminate = value === 'half'; this.checked = value === true; if (this.store.checkStrictly) return; if (!(this.shouldLoadData() && !this.store.checkDescendants)) { var _getChildState2 = getChildState(this.childNodes), all = _getChildState2.all, allWithoutDisable = _getChildState2.allWithoutDisable; if (!this.isLeaf && !all && allWithoutDisable) { this.checked = false; value = false; } var handleDescendants = function handleDescendants() { if (deep) { var childNodes = _this3.childNodes; for (var i = 0, j = childNodes.length; i < j; i++) { var child = childNodes[i]; passValue = passValue || value !== false; var isCheck = child.disabled ? child.checked : passValue; child.setChecked(isCheck, deep, true, passValue); } var _getChildState3 = getChildState(childNodes), half = _getChildState3.half, _all = _getChildState3.all; if (!_all) { _this3.checked = _all; _this3.indeterminate = half; } } }; if (this.shouldLoadData()) { // Only work on lazy load data. this.loadData(function () { handleDescendants(); reInitChecked(_this3); }, { checked: value !== false }); return; } else { handleDescendants(); } } var parent = this.parent; if (!parent || parent.level === 0) return; if (!recursion) { reInitChecked(parent); } }; Node.prototype.getChildren = function getChildren() { var forceInit = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; // this is data if (this.level === 0) return this.data; var data = this.data; if (!data) return null; var props = this.store.props; var children = 'children'; if (props) { children = props.children || 'children'; } if (data[children] === undefined) { data[children] = null; } if (forceInit && !data[children]) { data[children] = []; } return data[children]; }; Node.prototype.updateChildren = function updateChildren() { var _this4 = this; var newData = this.getChildren() || []; var oldData = this.childNodes.map(function (node) { return node.data; }); var newDataMap = {}; var newNodes = []; newData.forEach(function (item, index) { var key = item[NODE_KEY]; var isNodeExists = !!key && Object(util_["arrayFindIndex"])(oldData, function (data) { return data[NODE_KEY] === key; }) >= 0; if (isNodeExists) { newDataMap[key] = { index: index, data: item }; } else { newNodes.push({ index: index, data: item }); } }); if (!this.store.lazy) { oldData.forEach(function (item) { if (!newDataMap[item[NODE_KEY]]) _this4.removeChildByData(item); }); } newNodes.forEach(function (_ref) { var index = _ref.index, data = _ref.data; _this4.insertChild({ data: data }, index); }); this.updateLeafState(); }; Node.prototype.loadData = function loadData(callback) { var _this5 = this; var defaultProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; if (this.store.lazy === true && this.store.load && !this.loaded && (!this.loading || Object.keys(defaultProps).length)) { this.loading = true; var resolve = function resolve(children) { _this5.loaded = true; _this5.loading = false; _this5.childNodes = []; _this5.doCreateChildren(children, defaultProps); _this5.updateLeafState(); if (callback) { callback.call(_this5, children); } }; this.store.load(this, resolve); } else { if (callback) { callback.call(this); } } }; _createClass(Node, [{ key: 'label', get: function get() { return getPropertyFromData(this, 'label'); } }, { key: 'key', get: function get() { var nodeKey = this.store.key; if (this.data) return this.data[nodeKey]; return null; } }, { key: 'disabled', get: function get() { return getPropertyFromData(this, 'disabled'); } }, { key: 'nextSibling', get: function get() { var parent = this.parent; if (parent) { var index = parent.childNodes.indexOf(this); if (index > -1) { return parent.childNodes[index + 1]; } } return null; } }, { key: 'previousSibling', get: function get() { var parent = this.parent; if (parent) { var index = parent.childNodes.indexOf(this); if (index > -1) { return index > 0 ? parent.childNodes[index - 1] : null; } } return null; } }]); return Node; }(); /* harmony default export */ var model_node = (node_Node); // CONCATENATED MODULE: ./packages/tree/src/model/tree-store.js var tree_store_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; }; function tree_store_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var tree_store_TreeStore = function () { function TreeStore(options) { var _this = this; tree_store_classCallCheck(this, TreeStore); this.currentNode = null; this.currentNodeKey = null; for (var option in options) { if (options.hasOwnProperty(option)) { this[option] = options[option]; } } this.nodesMap = {}; this.root = new model_node({ data: this.data, store: this }); if (this.lazy && this.load) { var loadFn = this.load; loadFn(this.root, function (data) { _this.root.doCreateChildren(data); _this._initDefaultCheckedNodes(); }); } else { this._initDefaultCheckedNodes(); } } TreeStore.prototype.filter = function filter(value) { var filterNodeMethod = this.filterNodeMethod; var lazy = this.lazy; var traverse = function traverse(node) { var childNodes = node.root ? node.root.childNodes : node.childNodes; childNodes.forEach(function (child) { child.visible = filterNodeMethod.call(child, value, child.data, child); traverse(child); }); if (!node.visible && childNodes.length) { var allHidden = true; allHidden = !childNodes.some(function (child) { return child.visible; }); if (node.root) { node.root.visible = allHidden === false; } else { node.visible = allHidden === false; } } if (!value) return; if (node.visible && !node.isLeaf && !lazy) node.expand(); }; traverse(this); }; TreeStore.prototype.setData = function setData(newVal) { var instanceChanged = newVal !== this.root.data; if (instanceChanged) { this.root.setData(newVal); this._initDefaultCheckedNodes(); } else { this.root.updateChildren(); } }; TreeStore.prototype.getNode = function getNode(data) { if (data instanceof model_node) return data; var key = (typeof data === 'undefined' ? 'undefined' : tree_store_typeof(data)) !== 'object' ? data : util_getNodeKey(this.key, data); return this.nodesMap[key] || null; }; TreeStore.prototype.insertBefore = function insertBefore(data, refData) { var refNode = this.getNode(refData); refNode.parent.insertBefore({ data: data }, refNode); }; TreeStore.prototype.insertAfter = function insertAfter(data, refData) { var refNode = this.getNode(refData); refNode.parent.insertAfter({ data: data }, refNode); }; TreeStore.prototype.remove = function remove(data) { var node = this.getNode(data); if (node && node.parent) { if (node === this.currentNode) { this.currentNode = null; } node.parent.removeChild(node); } }; TreeStore.prototype.append = function append(data, parentData) { var parentNode = parentData ? this.getNode(parentData) : this.root; if (parentNode) { parentNode.insertChild({ data: data }); } }; TreeStore.prototype._initDefaultCheckedNodes = function _initDefaultCheckedNodes() { var _this2 = this; var defaultCheckedKeys = this.defaultCheckedKeys || []; var nodesMap = this.nodesMap; defaultCheckedKeys.forEach(function (checkedKey) { var node = nodesMap[checkedKey]; if (node) { node.setChecked(true, !_this2.checkStrictly); } }); }; TreeStore.prototype._initDefaultCheckedNode = function _initDefaultCheckedNode(node) { var defaultCheckedKeys = this.defaultCheckedKeys || []; if (defaultCheckedKeys.indexOf(node.key) !== -1) { node.setChecked(true, !this.checkStrictly); } }; TreeStore.prototype.setDefaultCheckedKey = function setDefaultCheckedKey(newVal) { if (newVal !== this.defaultCheckedKeys) { this.defaultCheckedKeys = newVal; this._initDefaultCheckedNodes(); } }; TreeStore.prototype.registerNode = function registerNode(node) { var key = this.key; if (!key || !node || !node.data) return; var nodeKey = node.key; if (nodeKey !== undefined) this.nodesMap[node.key] = node; }; TreeStore.prototype.deregisterNode = function deregisterNode(node) { var _this3 = this; var key = this.key; if (!key || !node || !node.data) return; node.childNodes.forEach(function (child) { _this3.deregisterNode(child); }); delete this.nodesMap[node.key]; }; TreeStore.prototype.getCheckedNodes = function getCheckedNodes() { var leafOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; var includeHalfChecked = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; var checkedNodes = []; var traverse = function traverse(node) { var childNodes = node.root ? node.root.childNodes : node.childNodes; childNodes.forEach(function (child) { if ((child.checked || includeHalfChecked && child.indeterminate) && (!leafOnly || leafOnly && child.isLeaf)) { checkedNodes.push(child.data); } traverse(child); }); }; traverse(this); return checkedNodes; }; TreeStore.prototype.getCheckedKeys = function getCheckedKeys() { var _this4 = this; var leafOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; return this.getCheckedNodes(leafOnly).map(function (data) { return (data || {})[_this4.key]; }); }; TreeStore.prototype.getHalfCheckedNodes = function getHalfCheckedNodes() { var nodes = []; var traverse = function traverse(node) { var childNodes = node.root ? node.root.childNodes : node.childNodes; childNodes.forEach(function (child) { if (child.indeterminate) { nodes.push(child.data); } traverse(child); }); }; traverse(this); return nodes; }; TreeStore.prototype.getHalfCheckedKeys = function getHalfCheckedKeys() { var _this5 = this; return this.getHalfCheckedNodes().map(function (data) { return (data || {})[_this5.key]; }); }; TreeStore.prototype._getAllNodes = function _getAllNodes() { var allNodes = []; var nodesMap = this.nodesMap; for (var nodeKey in nodesMap) { if (nodesMap.hasOwnProperty(nodeKey)) { allNodes.push(nodesMap[nodeKey]); } } return allNodes; }; TreeStore.prototype.updateChildren = function updateChildren(key, data) { var node = this.nodesMap[key]; if (!node) return; var childNodes = node.childNodes; for (var i = childNodes.length - 1; i >= 0; i--) { var child = childNodes[i]; this.remove(child.data); } for (var _i = 0, j = data.length; _i < j; _i++) { var _child = data[_i]; this.append(_child, node.data); } }; TreeStore.prototype._setCheckedKeys = function _setCheckedKeys(key) { var leafOnly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; var checkedKeys = arguments[2]; var allNodes = this._getAllNodes().sort(function (a, b) { return b.level - a.level; }); var cache = Object.create(null); var keys = Object.keys(checkedKeys); allNodes.forEach(function (node) { return node.setChecked(false, false); }); for (var i = 0, j = allNodes.length; i < j; i++) { var node = allNodes[i]; var nodeKey = node.data[key].toString(); var checked = keys.indexOf(nodeKey) > -1; if (!checked) { if (node.checked && !cache[nodeKey]) { node.setChecked(false, false); } continue; } var parent = node.parent; while (parent && parent.level > 0) { cache[parent.data[key]] = true; parent = parent.parent; } if (node.isLeaf || this.checkStrictly) { node.setChecked(true, false); continue; } node.setChecked(true, true); if (leafOnly) { (function () { node.setChecked(false, false); var traverse = function traverse(node) { var childNodes = node.childNodes; childNodes.forEach(function (child) { if (!child.isLeaf) { child.setChecked(false, false); } traverse(child); }); }; traverse(node); })(); } } }; TreeStore.prototype.setCheckedNodes = function setCheckedNodes(array) { var leafOnly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; var key = this.key; var checkedKeys = {}; array.forEach(function (item) { checkedKeys[(item || {})[key]] = true; }); this._setCheckedKeys(key, leafOnly, checkedKeys); }; TreeStore.prototype.setCheckedKeys = function setCheckedKeys(keys) { var leafOnly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; this.defaultCheckedKeys = keys; var key = this.key; var checkedKeys = {}; keys.forEach(function (key) { checkedKeys[key] = true; }); this._setCheckedKeys(key, leafOnly, checkedKeys); }; TreeStore.prototype.setDefaultExpandedKeys = function setDefaultExpandedKeys(keys) { var _this6 = this; keys = keys || []; this.defaultExpandedKeys = keys; keys.forEach(function (key) { var node = _this6.getNode(key); if (node) node.expand(null, _this6.autoExpandParent); }); }; TreeStore.prototype.setChecked = function setChecked(data, checked, deep) { var node = this.getNode(data); if (node) { node.setChecked(!!checked, deep); } }; TreeStore.prototype.getCurrentNode = function getCurrentNode() { return this.currentNode; }; TreeStore.prototype.setCurrentNode = function setCurrentNode(currentNode) { var prevCurrentNode = this.currentNode; if (prevCurrentNode) { prevCurrentNode.isCurrent = false; } this.currentNode = currentNode; this.currentNode.isCurrent = true; }; TreeStore.prototype.setUserCurrentNode = function setUserCurrentNode(node) { var key = node[this.key]; var currNode = this.nodesMap[key]; this.setCurrentNode(currNode); }; TreeStore.prototype.setCurrentNodeKey = function setCurrentNodeKey(key) { if (key === null || key === undefined) { this.currentNode && (this.currentNode.isCurrent = false); this.currentNode = null; return; } var node = this.getNode(key); if (node) { this.setCurrentNode(node); } }; return TreeStore; }(); /* harmony default export */ var tree_store = (tree_store_TreeStore); ; // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/tree/src/tree-node.vue?vue&type=template&id=3ba3ef0e& var tree_nodevue_type_template_id_3ba3ef0e_render = function() { var this$1 = this var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.node.visible, expression: "node.visible" } ], ref: "node", staticClass: "el-tree-node", class: { "is-expanded": _vm.expanded, "is-current": _vm.node.isCurrent, "is-hidden": !_vm.node.visible, "is-focusable": !_vm.node.disabled, "is-checked": !_vm.node.disabled && _vm.node.checked }, attrs: { role: "treeitem", tabindex: "-1", "aria-expanded": _vm.expanded, "aria-disabled": _vm.node.disabled, "aria-checked": _vm.node.checked, draggable: _vm.tree.draggable }, on: { click: function($event) { $event.stopPropagation() return _vm.handleClick($event) }, contextmenu: function($event) { return this$1.handleContextMenu($event) }, dragstart: function($event) { $event.stopPropagation() return _vm.handleDragStart($event) }, dragover: function($event) { $event.stopPropagation() return _vm.handleDragOver($event) }, dragend: function($event) { $event.stopPropagation() return _vm.handleDragEnd($event) }, drop: function($event) { $event.stopPropagation() return _vm.handleDrop($event) } } }, [ _c( "div", { staticClass: "el-tree-node__content", style: { "padding-left": (_vm.node.level - 1) * _vm.tree.indent + "px" } }, [ _c("span", { class: [ { "is-leaf": _vm.node.isLeaf, expanded: !_vm.node.isLeaf && _vm.expanded }, "el-tree-node__expand-icon", _vm.tree.iconClass ? _vm.tree.iconClass : "el-icon-caret-right" ], on: { click: function($event) { $event.stopPropagation() return _vm.handleExpandIconClick($event) } } }), _vm.showCheckbox ? _c("el-checkbox", { attrs: { indeterminate: _vm.node.indeterminate, disabled: !!_vm.node.disabled }, on: { change: _vm.handleCheckChange }, nativeOn: { click: function($event) { $event.stopPropagation() } }, model: { value: _vm.node.checked, callback: function($$v) { _vm.$set(_vm.node, "checked", $$v) }, expression: "node.checked" } }) : _vm._e(), _vm.node.loading ? _c("span", { staticClass: "el-tree-node__loading-icon el-icon-loading" }) : _vm._e(), _c("node-content", { attrs: { node: _vm.node } }) ], 1 ), _c("el-collapse-transition", [ !_vm.renderAfterExpand || _vm.childNodeRendered ? _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.expanded, expression: "expanded" } ], staticClass: "el-tree-node__children", attrs: { role: "group", "aria-expanded": _vm.expanded } }, _vm._l(_vm.node.childNodes, function(child) { return _c("el-tree-node", { key: _vm.getNodeKey(child), attrs: { "render-content": _vm.renderContent, "render-after-expand": _vm.renderAfterExpand, "show-checkbox": _vm.showCheckbox, node: child }, on: { "node-expand": _vm.handleChildNodeExpand } }) }), 1 ) : _vm._e() ]) ], 1 ) } var tree_nodevue_type_template_id_3ba3ef0e_staticRenderFns = [] tree_nodevue_type_template_id_3ba3ef0e_render._withStripped = true // CONCATENATED MODULE: ./packages/tree/src/tree-node.vue?vue&type=template&id=3ba3ef0e& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tree/src/tree-node.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var tree_nodevue_type_script_lang_js_ = ({ name: 'ElTreeNode', componentName: 'ElTreeNode', mixins: [emitter_default.a], props: { node: { default: function _default() { return {}; } }, props: {}, renderContent: Function, renderAfterExpand: { type: Boolean, default: true }, showCheckbox: { type: Boolean, default: false } }, components: { ElCollapseTransition: collapse_transition_default.a, ElCheckbox: checkbox_default.a, NodeContent: { props: { node: { required: true } }, render: function render(h) { var parent = this.$parent; var tree = parent.tree; var node = this.node; var data = node.data, store = node.store; return parent.renderContent ? parent.renderContent.call(parent._renderProxy, h, { _self: tree.$vnode.context, node: node, data: data, store: store }) : tree.$scopedSlots.default ? tree.$scopedSlots.default({ node: node, data: data }) : h( 'span', { 'class': 'el-tree-node__label' }, [node.label] ); } } }, data: function data() { return { tree: null, expanded: false, childNodeRendered: false, oldChecked: null, oldIndeterminate: null }; }, watch: { 'node.indeterminate': function nodeIndeterminate(val) { this.handleSelectChange(this.node.checked, val); }, 'node.checked': function nodeChecked(val) { this.handleSelectChange(val, this.node.indeterminate); }, 'node.expanded': function nodeExpanded(val) { var _this = this; this.$nextTick(function () { return _this.expanded = val; }); if (val) { this.childNodeRendered = true; } } }, methods: { getNodeKey: function getNodeKey(node) { return util_getNodeKey(this.tree.nodeKey, node.data); }, handleSelectChange: function handleSelectChange(checked, indeterminate) { if (this.oldChecked !== checked && this.oldIndeterminate !== indeterminate) { this.tree.$emit('check-change', this.node.data, checked, indeterminate); } this.oldChecked = checked; this.indeterminate = indeterminate; }, handleClick: function handleClick() { var store = this.tree.store; store.setCurrentNode(this.node); this.tree.$emit('current-change', store.currentNode ? store.currentNode.data : null, store.currentNode); this.tree.currentNode = this; if (this.tree.expandOnClickNode) { this.handleExpandIconClick(); } if (this.tree.checkOnClickNode && !this.node.disabled) { this.handleCheckChange(null, { target: { checked: !this.node.checked } }); } this.tree.$emit('node-click', this.node.data, this.node, this); }, handleContextMenu: function handleContextMenu(event) { if (this.tree._events['node-contextmenu'] && this.tree._events['node-contextmenu'].length > 0) { event.stopPropagation(); event.preventDefault(); } this.tree.$emit('node-contextmenu', event, this.node.data, this.node, this); }, handleExpandIconClick: function handleExpandIconClick() { if (this.node.isLeaf) return; if (this.expanded) { this.tree.$emit('node-collapse', this.node.data, this.node, this); this.node.collapse(); } else { this.node.expand(); this.$emit('node-expand', this.node.data, this.node, this); } }, handleCheckChange: function handleCheckChange(value, ev) { var _this2 = this; this.node.setChecked(ev.target.checked, !this.tree.checkStrictly); this.$nextTick(function () { var store = _this2.tree.store; _this2.tree.$emit('check', _this2.node.data, { checkedNodes: store.getCheckedNodes(), checkedKeys: store.getCheckedKeys(), halfCheckedNodes: store.getHalfCheckedNodes(), halfCheckedKeys: store.getHalfCheckedKeys() }); }); }, handleChildNodeExpand: function handleChildNodeExpand(nodeData, node, instance) { this.broadcast('ElTreeNode', 'tree-node-expand', node); this.tree.$emit('node-expand', nodeData, node, instance); }, handleDragStart: function handleDragStart(event) { if (!this.tree.draggable) return; this.tree.$emit('tree-node-drag-start', event, this); }, handleDragOver: function handleDragOver(event) { if (!this.tree.draggable) return; this.tree.$emit('tree-node-drag-over', event, this); event.preventDefault(); }, handleDrop: function handleDrop(event) { event.preventDefault(); }, handleDragEnd: function handleDragEnd(event) { if (!this.tree.draggable) return; this.tree.$emit('tree-node-drag-end', event, this); } }, created: function created() { var _this3 = this; var parent = this.$parent; if (parent.isTree) { this.tree = parent; } else { this.tree = parent.tree; } var tree = this.tree; if (!tree) { console.warn('Can not find node\'s tree.'); } var props = tree.props || {}; var childrenKey = props['children'] || 'children'; this.$watch('node.data.' + childrenKey, function () { _this3.node.updateChildren(); }); if (this.node.expanded) { this.expanded = true; this.childNodeRendered = true; } if (this.tree.accordion) { this.$on('tree-node-expand', function (node) { if (_this3.node !== node) { _this3.node.collapse(); } }); } } }); // CONCATENATED MODULE: ./packages/tree/src/tree-node.vue?vue&type=script&lang=js& /* harmony default export */ var src_tree_nodevue_type_script_lang_js_ = (tree_nodevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/tree/src/tree-node.vue /* normalize component */ var tree_node_component = normalizeComponent( src_tree_nodevue_type_script_lang_js_, tree_nodevue_type_template_id_3ba3ef0e_render, tree_nodevue_type_template_id_3ba3ef0e_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var tree_node_api; } tree_node_component.options.__file = "packages/tree/src/tree-node.vue" /* harmony default export */ var tree_node = (tree_node_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tree/src/tree.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var treevue_type_script_lang_js_ = ({ name: 'ElTree', mixins: [emitter_default.a], components: { ElTreeNode: tree_node }, data: function data() { return { store: null, root: null, currentNode: null, treeItems: null, checkboxItems: [], dragState: { showDropIndicator: false, draggingNode: null, dropNode: null, allowDrop: true } }; }, props: { data: { type: Array }, emptyText: { type: String, default: function _default() { return Object(lib_locale_["t"])('el.tree.emptyText'); } }, renderAfterExpand: { type: Boolean, default: true }, nodeKey: String, checkStrictly: Boolean, defaultExpandAll: Boolean, expandOnClickNode: { type: Boolean, default: true }, checkOnClickNode: Boolean, checkDescendants: { type: Boolean, default: false }, autoExpandParent: { type: Boolean, default: true }, defaultCheckedKeys: Array, defaultExpandedKeys: Array, currentNodeKey: [String, Number], renderContent: Function, showCheckbox: { type: Boolean, default: false }, draggable: { type: Boolean, default: false }, allowDrag: Function, allowDrop: Function, props: { default: function _default() { return { children: 'children', label: 'label', disabled: 'disabled' }; } }, lazy: { type: Boolean, default: false }, highlightCurrent: Boolean, load: Function, filterNodeMethod: Function, accordion: Boolean, indent: { type: Number, default: 18 }, iconClass: String }, computed: { children: { set: function set(value) { this.data = value; }, get: function get() { return this.data; } }, treeItemArray: function treeItemArray() { return Array.prototype.slice.call(this.treeItems); }, isEmpty: function isEmpty() { var childNodes = this.root.childNodes; return !childNodes || childNodes.length === 0 || childNodes.every(function (_ref) { var visible = _ref.visible; return !visible; }); } }, watch: { defaultCheckedKeys: function defaultCheckedKeys(newVal) { this.store.setDefaultCheckedKey(newVal); }, defaultExpandedKeys: function defaultExpandedKeys(newVal) { this.store.defaultExpandedKeys = newVal; this.store.setDefaultExpandedKeys(newVal); }, data: function data(newVal) { this.store.setData(newVal); }, checkboxItems: function checkboxItems(val) { Array.prototype.forEach.call(val, function (checkbox) { checkbox.setAttribute('tabindex', -1); }); }, checkStrictly: function checkStrictly(newVal) { this.store.checkStrictly = newVal; } }, methods: { filter: function filter(value) { if (!this.filterNodeMethod) throw new Error('[Tree] filterNodeMethod is required when filter'); this.store.filter(value); }, getNodeKey: function getNodeKey(node) { return util_getNodeKey(this.nodeKey, node.data); }, getNodePath: function getNodePath(data) { if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in getNodePath'); var node = this.store.getNode(data); if (!node) return []; var path = [node.data]; var parent = node.parent; while (parent && parent !== this.root) { path.push(parent.data); parent = parent.parent; } return path.reverse(); }, getCheckedNodes: function getCheckedNodes(leafOnly, includeHalfChecked) { return this.store.getCheckedNodes(leafOnly, includeHalfChecked); }, getCheckedKeys: function getCheckedKeys(leafOnly) { return this.store.getCheckedKeys(leafOnly); }, getCurrentNode: function getCurrentNode() { var currentNode = this.store.getCurrentNode(); return currentNode ? currentNode.data : null; }, getCurrentKey: function getCurrentKey() { if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in getCurrentKey'); var currentNode = this.getCurrentNode(); return currentNode ? currentNode[this.nodeKey] : null; }, setCheckedNodes: function setCheckedNodes(nodes, leafOnly) { if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCheckedNodes'); this.store.setCheckedNodes(nodes, leafOnly); }, setCheckedKeys: function setCheckedKeys(keys, leafOnly) { if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCheckedKeys'); this.store.setCheckedKeys(keys, leafOnly); }, setChecked: function setChecked(data, checked, deep) { this.store.setChecked(data, checked, deep); }, getHalfCheckedNodes: function getHalfCheckedNodes() { return this.store.getHalfCheckedNodes(); }, getHalfCheckedKeys: function getHalfCheckedKeys() { return this.store.getHalfCheckedKeys(); }, setCurrentNode: function setCurrentNode(node) { if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCurrentNode'); this.store.setUserCurrentNode(node); }, setCurrentKey: function setCurrentKey(key) { if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCurrentKey'); this.store.setCurrentNodeKey(key); }, getNode: function getNode(data) { return this.store.getNode(data); }, remove: function remove(data) { this.store.remove(data); }, append: function append(data, parentNode) { this.store.append(data, parentNode); }, insertBefore: function insertBefore(data, refNode) { this.store.insertBefore(data, refNode); }, insertAfter: function insertAfter(data, refNode) { this.store.insertAfter(data, refNode); }, handleNodeExpand: function handleNodeExpand(nodeData, node, instance) { this.broadcast('ElTreeNode', 'tree-node-expand', node); this.$emit('node-expand', nodeData, node, instance); }, updateKeyChildren: function updateKeyChildren(key, data) { if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in updateKeyChild'); this.store.updateChildren(key, data); }, initTabIndex: function initTabIndex() { this.treeItems = this.$el.querySelectorAll('.is-focusable[role=treeitem]'); this.checkboxItems = this.$el.querySelectorAll('input[type=checkbox]'); var checkedItem = this.$el.querySelectorAll('.is-checked[role=treeitem]'); if (checkedItem.length) { checkedItem[0].setAttribute('tabindex', 0); return; } this.treeItems[0] && this.treeItems[0].setAttribute('tabindex', 0); }, handleKeydown: function handleKeydown(ev) { var currentItem = ev.target; if (currentItem.className.indexOf('el-tree-node') === -1) return; var keyCode = ev.keyCode; this.treeItems = this.$el.querySelectorAll('.is-focusable[role=treeitem]'); var currentIndex = this.treeItemArray.indexOf(currentItem); var nextIndex = void 0; if ([38, 40].indexOf(keyCode) > -1) { // up、down ev.preventDefault(); if (keyCode === 38) { // up nextIndex = currentIndex !== 0 ? currentIndex - 1 : 0; } else { nextIndex = currentIndex < this.treeItemArray.length - 1 ? currentIndex + 1 : 0; } this.treeItemArray[nextIndex].focus(); // 选中 } if ([37, 39].indexOf(keyCode) > -1) { // left、right 展开 ev.preventDefault(); currentItem.click(); // 选中 } var hasInput = currentItem.querySelector('[type="checkbox"]'); if ([13, 32].indexOf(keyCode) > -1 && hasInput) { // space enter选中checkbox ev.preventDefault(); hasInput.click(); } } }, created: function created() { var _this = this; this.isTree = true; this.store = new tree_store({ key: this.nodeKey, data: this.data, lazy: this.lazy, props: this.props, load: this.load, currentNodeKey: this.currentNodeKey, checkStrictly: this.checkStrictly, checkDescendants: this.checkDescendants, defaultCheckedKeys: this.defaultCheckedKeys, defaultExpandedKeys: this.defaultExpandedKeys, autoExpandParent: this.autoExpandParent, defaultExpandAll: this.defaultExpandAll, filterNodeMethod: this.filterNodeMethod }); this.root = this.store.root; var dragState = this.dragState; this.$on('tree-node-drag-start', function (event, treeNode) { if (typeof _this.allowDrag === 'function' && !_this.allowDrag(treeNode.node)) { event.preventDefault(); return false; } event.dataTransfer.effectAllowed = 'move'; // wrap in try catch to address IE's error when first param is 'text/plain' try { // setData is required for draggable to work in FireFox // the content has to be '' so dragging a node out of the tree won't open a new tab in FireFox event.dataTransfer.setData('text/plain', ''); } catch (e) {} dragState.draggingNode = treeNode; _this.$emit('node-drag-start', treeNode.node, event); }); this.$on('tree-node-drag-over', function (event, treeNode) { var dropNode = findNearestComponent(event.target, 'ElTreeNode'); var oldDropNode = dragState.dropNode; if (oldDropNode && oldDropNode !== dropNode) { Object(dom_["removeClass"])(oldDropNode.$el, 'is-drop-inner'); } var draggingNode = dragState.draggingNode; if (!draggingNode || !dropNode) return; var dropPrev = true; var dropInner = true; var dropNext = true; var userAllowDropInner = true; if (typeof _this.allowDrop === 'function') { dropPrev = _this.allowDrop(draggingNode.node, dropNode.node, 'prev'); userAllowDropInner = dropInner = _this.allowDrop(draggingNode.node, dropNode.node, 'inner'); dropNext = _this.allowDrop(draggingNode.node, dropNode.node, 'next'); } event.dataTransfer.dropEffect = dropInner ? 'move' : 'none'; if ((dropPrev || dropInner || dropNext) && oldDropNode !== dropNode) { if (oldDropNode) { _this.$emit('node-drag-leave', draggingNode.node, oldDropNode.node, event); } _this.$emit('node-drag-enter', draggingNode.node, dropNode.node, event); } if (dropPrev || dropInner || dropNext) { dragState.dropNode = dropNode; } if (dropNode.node.nextSibling === draggingNode.node) { dropNext = false; } if (dropNode.node.previousSibling === draggingNode.node) { dropPrev = false; } if (dropNode.node.contains(draggingNode.node, false)) { dropInner = false; } if (draggingNode.node === dropNode.node || draggingNode.node.contains(dropNode.node)) { dropPrev = false; dropInner = false; dropNext = false; } var targetPosition = dropNode.$el.getBoundingClientRect(); var treePosition = _this.$el.getBoundingClientRect(); var dropType = void 0; var prevPercent = dropPrev ? dropInner ? 0.25 : dropNext ? 0.45 : 1 : -1; var nextPercent = dropNext ? dropInner ? 0.75 : dropPrev ? 0.55 : 0 : 1; var indicatorTop = -9999; var distance = event.clientY - targetPosition.top; if (distance < targetPosition.height * prevPercent) { dropType = 'before'; } else if (distance > targetPosition.height * nextPercent) { dropType = 'after'; } else if (dropInner) { dropType = 'inner'; } else { dropType = 'none'; } var iconPosition = dropNode.$el.querySelector('.el-tree-node__expand-icon').getBoundingClientRect(); var dropIndicator = _this.$refs.dropIndicator; if (dropType === 'before') { indicatorTop = iconPosition.top - treePosition.top; } else if (dropType === 'after') { indicatorTop = iconPosition.bottom - treePosition.top; } dropIndicator.style.top = indicatorTop + 'px'; dropIndicator.style.left = iconPosition.right - treePosition.left + 'px'; if (dropType === 'inner') { Object(dom_["addClass"])(dropNode.$el, 'is-drop-inner'); } else { Object(dom_["removeClass"])(dropNode.$el, 'is-drop-inner'); } dragState.showDropIndicator = dropType === 'before' || dropType === 'after'; dragState.allowDrop = dragState.showDropIndicator || userAllowDropInner; dragState.dropType = dropType; _this.$emit('node-drag-over', draggingNode.node, dropNode.node, event); }); this.$on('tree-node-drag-end', function (event) { var draggingNode = dragState.draggingNode, dropType = dragState.dropType, dropNode = dragState.dropNode; event.preventDefault(); event.dataTransfer.dropEffect = 'move'; if (draggingNode && dropNode) { var draggingNodeCopy = { data: draggingNode.node.data }; if (dropType !== 'none') { draggingNode.node.remove(); } if (dropType === 'before') { dropNode.node.parent.insertBefore(draggingNodeCopy, dropNode.node); } else if (dropType === 'after') { dropNode.node.parent.insertAfter(draggingNodeCopy, dropNode.node); } else if (dropType === 'inner') { dropNode.node.insertChild(draggingNodeCopy); } if (dropType !== 'none') { _this.store.registerNode(draggingNodeCopy); } Object(dom_["removeClass"])(dropNode.$el, 'is-drop-inner'); _this.$emit('node-drag-end', draggingNode.node, dropNode.node, dropType, event); if (dropType !== 'none') { _this.$emit('node-drop', draggingNode.node, dropNode.node, dropType, event); } } if (draggingNode && !dropNode) { _this.$emit('node-drag-end', draggingNode.node, null, dropType, event); } dragState.showDropIndicator = false; dragState.draggingNode = null; dragState.dropNode = null; dragState.allowDrop = true; }); }, mounted: function mounted() { this.initTabIndex(); this.$el.addEventListener('keydown', this.handleKeydown); }, updated: function updated() { this.treeItems = this.$el.querySelectorAll('[role=treeitem]'); this.checkboxItems = this.$el.querySelectorAll('input[type=checkbox]'); } }); // CONCATENATED MODULE: ./packages/tree/src/tree.vue?vue&type=script&lang=js& /* harmony default export */ var src_treevue_type_script_lang_js_ = (treevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/tree/src/tree.vue /* normalize component */ var tree_component = normalizeComponent( src_treevue_type_script_lang_js_, treevue_type_template_id_547575a6_render, treevue_type_template_id_547575a6_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var tree_api; } tree_component.options.__file = "packages/tree/src/tree.vue" /* harmony default export */ var src_tree = (tree_component.exports); // CONCATENATED MODULE: ./packages/tree/index.js /* istanbul ignore next */ src_tree.install = function (Vue) { Vue.component(src_tree.name, src_tree); }; /* harmony default export */ var packages_tree = (src_tree); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/alert/src/main.vue?vue&type=template&id=6e53341b& var mainvue_type_template_id_6e53341b_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("transition", { attrs: { name: "el-alert-fade" } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-alert", class: [ _vm.typeClass, _vm.center ? "is-center" : "", "is-" + _vm.effect ], attrs: { role: "alert" } }, [ _vm.showIcon ? _c("i", { staticClass: "el-alert__icon", class: [_vm.iconClass, _vm.isBigIcon] }) : _vm._e(), _c("div", { staticClass: "el-alert__content" }, [ _vm.title || _vm.$slots.title ? _c( "span", { staticClass: "el-alert__title", class: [_vm.isBoldTitle] }, [_vm._t("title", [_vm._v(_vm._s(_vm.title))])], 2 ) : _vm._e(), _vm.$slots.default && !_vm.description ? _c( "p", { staticClass: "el-alert__description" }, [_vm._t("default")], 2 ) : _vm._e(), _vm.description && !_vm.$slots.default ? _c("p", { staticClass: "el-alert__description" }, [ _vm._v(_vm._s(_vm.description)) ]) : _vm._e(), _c( "i", { directives: [ { name: "show", rawName: "v-show", value: _vm.closable, expression: "closable" } ], staticClass: "el-alert__closebtn", class: { "is-customed": _vm.closeText !== "", "el-icon-close": _vm.closeText === "" }, on: { click: function($event) { _vm.close() } } }, [_vm._v(_vm._s(_vm.closeText))] ) ]) ] ) ]) } var mainvue_type_template_id_6e53341b_staticRenderFns = [] mainvue_type_template_id_6e53341b_render._withStripped = true // CONCATENATED MODULE: ./packages/alert/src/main.vue?vue&type=template&id=6e53341b& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/alert/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // var TYPE_CLASSES_MAP = { 'success': 'el-icon-success', 'warning': 'el-icon-warning', 'error': 'el-icon-error' }; /* harmony default export */ var alert_src_mainvue_type_script_lang_js_ = ({ name: 'ElAlert', props: { title: { type: String, default: '' }, description: { type: String, default: '' }, type: { type: String, default: 'info' }, closable: { type: Boolean, default: true }, closeText: { type: String, default: '' }, showIcon: Boolean, center: Boolean, effect: { type: String, default: 'light', validator: function validator(value) { return ['light', 'dark'].indexOf(value) !== -1; } } }, data: function data() { return { visible: true }; }, methods: { close: function close() { this.visible = false; this.$emit('close'); } }, computed: { typeClass: function typeClass() { return 'el-alert--' + this.type; }, iconClass: function iconClass() { return TYPE_CLASSES_MAP[this.type] || 'el-icon-info'; }, isBigIcon: function isBigIcon() { return this.description || this.$slots.default ? 'is-big' : ''; }, isBoldTitle: function isBoldTitle() { return this.description || this.$slots.default ? 'is-bold' : ''; } } }); // CONCATENATED MODULE: ./packages/alert/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_alert_src_mainvue_type_script_lang_js_ = (alert_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/alert/src/main.vue /* normalize component */ var alert_src_main_component = normalizeComponent( packages_alert_src_mainvue_type_script_lang_js_, mainvue_type_template_id_6e53341b_render, mainvue_type_template_id_6e53341b_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var alert_src_main_api; } alert_src_main_component.options.__file = "packages/alert/src/main.vue" /* harmony default export */ var alert_src_main = (alert_src_main_component.exports); // CONCATENATED MODULE: ./packages/alert/index.js /* istanbul ignore next */ alert_src_main.install = function (Vue) { Vue.component(alert_src_main.name, alert_src_main); }; /* harmony default export */ var packages_alert = (alert_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/notification/src/main.vue?vue&type=template&id=43dbc3d8& var mainvue_type_template_id_43dbc3d8_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("transition", { attrs: { name: "el-notification-fade" } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], class: ["el-notification", _vm.customClass, _vm.horizontalClass], style: _vm.positionStyle, attrs: { role: "alert" }, on: { mouseenter: function($event) { _vm.clearTimer() }, mouseleave: function($event) { _vm.startTimer() }, click: _vm.click } }, [ _vm.type || _vm.iconClass ? _c("i", { staticClass: "el-notification__icon", class: [_vm.typeClass, _vm.iconClass] }) : _vm._e(), _c( "div", { staticClass: "el-notification__group", class: { "is-with-icon": _vm.typeClass || _vm.iconClass } }, [ _c("h2", { staticClass: "el-notification__title", domProps: { textContent: _vm._s(_vm.title) } }), _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.message, expression: "message" } ], staticClass: "el-notification__content" }, [ _vm._t("default", [ !_vm.dangerouslyUseHTMLString ? _c("p", [_vm._v(_vm._s(_vm.message))]) : _c("p", { domProps: { innerHTML: _vm._s(_vm.message) } }) ]) ], 2 ), _vm.showClose ? _c("div", { staticClass: "el-notification__closeBtn el-icon-close", on: { click: function($event) { $event.stopPropagation() return _vm.close($event) } } }) : _vm._e() ] ) ] ) ]) } var mainvue_type_template_id_43dbc3d8_staticRenderFns = [] mainvue_type_template_id_43dbc3d8_render._withStripped = true // CONCATENATED MODULE: ./packages/notification/src/main.vue?vue&type=template&id=43dbc3d8& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/notification/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var mainvue_type_script_lang_js_typeMap = { success: 'success', info: 'info', warning: 'warning', error: 'error' }; /* harmony default export */ var notification_src_mainvue_type_script_lang_js_ = ({ data: function data() { return { visible: false, title: '', message: '', duration: 4500, type: '', showClose: true, customClass: '', iconClass: '', onClose: null, onClick: null, closed: false, verticalOffset: 0, timer: null, dangerouslyUseHTMLString: false, position: 'top-right' }; }, computed: { typeClass: function typeClass() { return this.type && mainvue_type_script_lang_js_typeMap[this.type] ? 'el-icon-' + mainvue_type_script_lang_js_typeMap[this.type] : ''; }, horizontalClass: function horizontalClass() { return this.position.indexOf('right') > -1 ? 'right' : 'left'; }, verticalProperty: function verticalProperty() { return (/^top-/.test(this.position) ? 'top' : 'bottom' ); }, positionStyle: function positionStyle() { var _ref; return _ref = {}, _ref[this.verticalProperty] = this.verticalOffset + 'px', _ref; } }, watch: { closed: function closed(newVal) { if (newVal) { this.visible = false; this.$el.addEventListener('transitionend', this.destroyElement); } } }, methods: { destroyElement: function destroyElement() { this.$el.removeEventListener('transitionend', this.destroyElement); this.$destroy(true); this.$el.parentNode.removeChild(this.$el); }, click: function click() { if (typeof this.onClick === 'function') { this.onClick(); } }, close: function close() { this.closed = true; if (typeof this.onClose === 'function') { this.onClose(); } }, clearTimer: function clearTimer() { clearTimeout(this.timer); }, startTimer: function startTimer() { var _this = this; if (this.duration > 0) { this.timer = setTimeout(function () { if (!_this.closed) { _this.close(); } }, this.duration); } }, keydown: function keydown(e) { if (e.keyCode === 46 || e.keyCode === 8) { this.clearTimer(); // detele 取消倒计时 } else if (e.keyCode === 27) { // esc关闭消息 if (!this.closed) { this.close(); } } else { this.startTimer(); // 恢复倒计时 } } }, mounted: function mounted() { var _this2 = this; if (this.duration > 0) { this.timer = setTimeout(function () { if (!_this2.closed) { _this2.close(); } }, this.duration); } document.addEventListener('keydown', this.keydown); }, beforeDestroy: function beforeDestroy() { document.removeEventListener('keydown', this.keydown); } }); // CONCATENATED MODULE: ./packages/notification/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_notification_src_mainvue_type_script_lang_js_ = (notification_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/notification/src/main.vue /* normalize component */ var notification_src_main_component = normalizeComponent( packages_notification_src_mainvue_type_script_lang_js_, mainvue_type_template_id_43dbc3d8_render, mainvue_type_template_id_43dbc3d8_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var notification_src_main_api; } notification_src_main_component.options.__file = "packages/notification/src/main.vue" /* harmony default export */ var notification_src_main = (notification_src_main_component.exports); // CONCATENATED MODULE: ./packages/notification/src/main.js var NotificationConstructor = external_vue_default.a.extend(notification_src_main); var src_main_instance = void 0; var instances = []; var seed = 1; var main_Notification = function Notification(options) { if (external_vue_default.a.prototype.$isServer) return; options = merge_default()({}, options); var userOnClose = options.onClose; var id = 'notification_' + seed++; var position = options.position || 'top-right'; options.onClose = function () { Notification.close(id, userOnClose); }; src_main_instance = new NotificationConstructor({ data: options }); if (Object(vdom_["isVNode"])(options.message)) { src_main_instance.$slots.default = [options.message]; options.message = 'REPLACED_BY_VNODE'; } src_main_instance.id = id; src_main_instance.$mount(); document.body.appendChild(src_main_instance.$el); src_main_instance.visible = true; src_main_instance.dom = src_main_instance.$el; src_main_instance.dom.style.zIndex = popup_["PopupManager"].nextZIndex(); var verticalOffset = options.offset || 0; instances.filter(function (item) { return item.position === position; }).forEach(function (item) { verticalOffset += item.$el.offsetHeight + 16; }); verticalOffset += 16; src_main_instance.verticalOffset = verticalOffset; instances.push(src_main_instance); return src_main_instance; }; ['success', 'warning', 'info', 'error'].forEach(function (type) { main_Notification[type] = function (options) { if (typeof options === 'string' || Object(vdom_["isVNode"])(options)) { options = { message: options }; } options.type = type; return main_Notification(options); }; }); main_Notification.close = function (id, userOnClose) { var index = -1; var len = instances.length; var instance = instances.filter(function (instance, i) { if (instance.id === id) { index = i; return true; } return false; })[0]; if (!instance) return; if (typeof userOnClose === 'function') { userOnClose(instance); } instances.splice(index, 1); if (len <= 1) return; var position = instance.position; var removedHeight = instance.dom.offsetHeight; for (var i = index; i < len - 1; i++) { if (instances[i].position === position) { instances[i].dom.style[instance.verticalProperty] = parseInt(instances[i].dom.style[instance.verticalProperty], 10) - removedHeight - 16 + 'px'; } } }; main_Notification.closeAll = function () { for (var i = instances.length - 1; i >= 0; i--) { instances[i].close(); } }; /* harmony default export */ var packages_notification_src_main = (main_Notification); // CONCATENATED MODULE: ./packages/notification/index.js /* harmony default export */ var notification = (packages_notification_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/slider/src/main.vue?vue&type=template&id=32708644& var mainvue_type_template_id_32708644_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-slider", class: { "is-vertical": _vm.vertical, "el-slider--with-input": _vm.showInput }, attrs: { role: "slider", "aria-valuemin": _vm.min, "aria-valuemax": _vm.max, "aria-orientation": _vm.vertical ? "vertical" : "horizontal", "aria-disabled": _vm.sliderDisabled } }, [ _vm.showInput && !_vm.range ? _c("el-input-number", { ref: "input", staticClass: "el-slider__input", attrs: { step: _vm.step, disabled: _vm.sliderDisabled, controls: _vm.showInputControls, min: _vm.min, max: _vm.max, debounce: _vm.debounce, size: _vm.inputSize }, on: { change: _vm.emitChange }, model: { value: _vm.firstValue, callback: function($$v) { _vm.firstValue = $$v }, expression: "firstValue" } }) : _vm._e(), _c( "div", { ref: "slider", staticClass: "el-slider__runway", class: { "show-input": _vm.showInput, disabled: _vm.sliderDisabled }, style: _vm.runwayStyle, on: { click: _vm.onSliderClick } }, [ _c("div", { staticClass: "el-slider__bar", style: _vm.barStyle }), _c("slider-button", { ref: "button1", attrs: { vertical: _vm.vertical, "tooltip-class": _vm.tooltipClass }, model: { value: _vm.firstValue, callback: function($$v) { _vm.firstValue = $$v }, expression: "firstValue" } }), _vm.range ? _c("slider-button", { ref: "button2", attrs: { vertical: _vm.vertical, "tooltip-class": _vm.tooltipClass }, model: { value: _vm.secondValue, callback: function($$v) { _vm.secondValue = $$v }, expression: "secondValue" } }) : _vm._e(), _vm._l(_vm.stops, function(item, key) { return _vm.showStops ? _c("div", { key: key, staticClass: "el-slider__stop", style: _vm.getStopStyle(item) }) : _vm._e() }), _vm.markList.length > 0 ? [ _c( "div", _vm._l(_vm.markList, function(item, key) { return _c("div", { key: key, staticClass: "el-slider__stop el-slider__marks-stop", style: _vm.getStopStyle(item.position) }) }), 0 ), _c( "div", { staticClass: "el-slider__marks" }, _vm._l(_vm.markList, function(item, key) { return _c("slider-marker", { key: key, style: _vm.getStopStyle(item.position), attrs: { mark: item.mark } }) }), 1 ) ] : _vm._e() ], 2 ) ], 1 ) } var mainvue_type_template_id_32708644_staticRenderFns = [] mainvue_type_template_id_32708644_render._withStripped = true // CONCATENATED MODULE: ./packages/slider/src/main.vue?vue&type=template&id=32708644& // EXTERNAL MODULE: external "element-ui/lib/input-number" var input_number_ = __webpack_require__(41); var input_number_default = /*#__PURE__*/__webpack_require__.n(input_number_); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/slider/src/button.vue?vue&type=template&id=e72d2ad2& var buttonvue_type_template_id_e72d2ad2_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { ref: "button", staticClass: "el-slider__button-wrapper", class: { hover: _vm.hovering, dragging: _vm.dragging }, style: _vm.wrapperStyle, attrs: { tabindex: "0" }, on: { mouseenter: _vm.handleMouseEnter, mouseleave: _vm.handleMouseLeave, mousedown: _vm.onButtonDown, touchstart: _vm.onButtonDown, focus: _vm.handleMouseEnter, blur: _vm.handleMouseLeave, keydown: [ function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "left", 37, $event.key, [ "Left", "ArrowLeft" ]) ) { return null } if ("button" in $event && $event.button !== 0) { return null } return _vm.onLeftKeyDown($event) }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "right", 39, $event.key, [ "Right", "ArrowRight" ]) ) { return null } if ("button" in $event && $event.button !== 2) { return null } return _vm.onRightKeyDown($event) }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "down", 40, $event.key, [ "Down", "ArrowDown" ]) ) { return null } $event.preventDefault() return _vm.onLeftKeyDown($event) }, function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "up", 38, $event.key, ["Up", "ArrowUp"]) ) { return null } $event.preventDefault() return _vm.onRightKeyDown($event) } ] } }, [ _c( "el-tooltip", { ref: "tooltip", attrs: { placement: "top", "popper-class": _vm.tooltipClass, disabled: !_vm.showTooltip } }, [ _c("span", { attrs: { slot: "content" }, slot: "content" }, [ _vm._v(_vm._s(_vm.formatValue)) ]), _c("div", { staticClass: "el-slider__button", class: { hover: _vm.hovering, dragging: _vm.dragging } }) ] ) ], 1 ) } var buttonvue_type_template_id_e72d2ad2_staticRenderFns = [] buttonvue_type_template_id_e72d2ad2_render._withStripped = true // CONCATENATED MODULE: ./packages/slider/src/button.vue?vue&type=template&id=e72d2ad2& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/slider/src/button.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var slider_src_buttonvue_type_script_lang_js_ = ({ name: 'ElSliderButton', components: { ElTooltip: tooltip_default.a }, props: { value: { type: Number, default: 0 }, vertical: { type: Boolean, default: false }, tooltipClass: String }, data: function data() { return { hovering: false, dragging: false, isClick: false, startX: 0, currentX: 0, startY: 0, currentY: 0, startPosition: 0, newPosition: null, oldValue: this.value }; }, computed: { disabled: function disabled() { return this.$parent.sliderDisabled; }, max: function max() { return this.$parent.max; }, min: function min() { return this.$parent.min; }, step: function step() { return this.$parent.step; }, showTooltip: function showTooltip() { return this.$parent.showTooltip; }, precision: function precision() { return this.$parent.precision; }, currentPosition: function currentPosition() { return (this.value - this.min) / (this.max - this.min) * 100 + '%'; }, enableFormat: function enableFormat() { return this.$parent.formatTooltip instanceof Function; }, formatValue: function formatValue() { return this.enableFormat && this.$parent.formatTooltip(this.value) || this.value; }, wrapperStyle: function wrapperStyle() { return this.vertical ? { bottom: this.currentPosition } : { left: this.currentPosition }; } }, watch: { dragging: function dragging(val) { this.$parent.dragging = val; } }, methods: { displayTooltip: function displayTooltip() { this.$refs.tooltip && (this.$refs.tooltip.showPopper = true); }, hideTooltip: function hideTooltip() { this.$refs.tooltip && (this.$refs.tooltip.showPopper = false); }, handleMouseEnter: function handleMouseEnter() { this.hovering = true; this.displayTooltip(); }, handleMouseLeave: function handleMouseLeave() { this.hovering = false; this.hideTooltip(); }, onButtonDown: function onButtonDown(event) { if (this.disabled) return; event.preventDefault(); this.onDragStart(event); window.addEventListener('mousemove', this.onDragging); window.addEventListener('touchmove', this.onDragging); window.addEventListener('mouseup', this.onDragEnd); window.addEventListener('touchend', this.onDragEnd); window.addEventListener('contextmenu', this.onDragEnd); }, onLeftKeyDown: function onLeftKeyDown() { if (this.disabled) return; this.newPosition = parseFloat(this.currentPosition) - this.step / (this.max - this.min) * 100; this.setPosition(this.newPosition); this.$parent.emitChange(); }, onRightKeyDown: function onRightKeyDown() { if (this.disabled) return; this.newPosition = parseFloat(this.currentPosition) + this.step / (this.max - this.min) * 100; this.setPosition(this.newPosition); this.$parent.emitChange(); }, onDragStart: function onDragStart(event) { this.dragging = true; this.isClick = true; if (event.type === 'touchstart') { event.clientY = event.touches[0].clientY; event.clientX = event.touches[0].clientX; } if (this.vertical) { this.startY = event.clientY; } else { this.startX = event.clientX; } this.startPosition = parseFloat(this.currentPosition); this.newPosition = this.startPosition; }, onDragging: function onDragging(event) { if (this.dragging) { this.isClick = false; this.displayTooltip(); this.$parent.resetSize(); var diff = 0; if (event.type === 'touchmove') { event.clientY = event.touches[0].clientY; event.clientX = event.touches[0].clientX; } if (this.vertical) { this.currentY = event.clientY; diff = (this.startY - this.currentY) / this.$parent.sliderSize * 100; } else { this.currentX = event.clientX; diff = (this.currentX - this.startX) / this.$parent.sliderSize * 100; } this.newPosition = this.startPosition + diff; this.setPosition(this.newPosition); } }, onDragEnd: function onDragEnd() { var _this = this; if (this.dragging) { /* * 防止在 mouseup 后立即触发 click,导致滑块有几率产生一小段位移 * 不使用 preventDefault 是因为 mouseup 和 click 没有注册在同一个 DOM 上 */ setTimeout(function () { _this.dragging = false; _this.hideTooltip(); if (!_this.isClick) { _this.setPosition(_this.newPosition); _this.$parent.emitChange(); } }, 0); window.removeEventListener('mousemove', this.onDragging); window.removeEventListener('touchmove', this.onDragging); window.removeEventListener('mouseup', this.onDragEnd); window.removeEventListener('touchend', this.onDragEnd); window.removeEventListener('contextmenu', this.onDragEnd); } }, setPosition: function setPosition(newPosition) { var _this2 = this; if (newPosition === null || isNaN(newPosition)) return; if (newPosition < 0) { newPosition = 0; } else if (newPosition > 100) { newPosition = 100; } var lengthPerStep = 100 / ((this.max - this.min) / this.step); var steps = Math.round(newPosition / lengthPerStep); var value = steps * lengthPerStep * (this.max - this.min) * 0.01 + this.min; value = parseFloat(value.toFixed(this.precision)); this.$emit('input', value); this.$nextTick(function () { _this2.displayTooltip(); _this2.$refs.tooltip && _this2.$refs.tooltip.updatePopper(); }); if (!this.dragging && this.value !== this.oldValue) { this.oldValue = this.value; } } } }); // CONCATENATED MODULE: ./packages/slider/src/button.vue?vue&type=script&lang=js& /* harmony default export */ var packages_slider_src_buttonvue_type_script_lang_js_ = (slider_src_buttonvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/slider/src/button.vue /* normalize component */ var src_button_component = normalizeComponent( packages_slider_src_buttonvue_type_script_lang_js_, buttonvue_type_template_id_e72d2ad2_render, buttonvue_type_template_id_e72d2ad2_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var src_button_api; } src_button_component.options.__file = "packages/slider/src/button.vue" /* harmony default export */ var slider_src_button = (src_button_component.exports); // CONCATENATED MODULE: ./packages/slider/src/marker.js /* harmony default export */ var marker = ({ name: 'ElMarker', props: { mark: { type: [String, Object] } }, render: function render() { var h = arguments[0]; var label = typeof this.mark === 'string' ? this.mark : this.mark.label; return h( 'div', { 'class': 'el-slider__marks-text', style: this.mark.style || {} }, [label] ); } }); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/slider/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var slider_src_mainvue_type_script_lang_js_ = ({ name: 'ElSlider', mixins: [emitter_default.a], inject: { elForm: { default: '' } }, props: { min: { type: Number, default: 0 }, max: { type: Number, default: 100 }, step: { type: Number, default: 1 }, value: { type: [Number, Array], default: 0 }, showInput: { type: Boolean, default: false }, showInputControls: { type: Boolean, default: true }, inputSize: { type: String, default: 'small' }, showStops: { type: Boolean, default: false }, showTooltip: { type: Boolean, default: true }, formatTooltip: Function, disabled: { type: Boolean, default: false }, range: { type: Boolean, default: false }, vertical: { type: Boolean, default: false }, height: { type: String }, debounce: { type: Number, default: 300 }, label: { type: String }, tooltipClass: String, marks: Object }, components: { ElInputNumber: input_number_default.a, SliderButton: slider_src_button, SliderMarker: marker }, data: function data() { return { firstValue: null, secondValue: null, oldValue: null, dragging: false, sliderSize: 1 }; }, watch: { value: function value(val, oldVal) { if (this.dragging || Array.isArray(val) && Array.isArray(oldVal) && val.every(function (item, index) { return item === oldVal[index]; })) { return; } this.setValues(); }, dragging: function dragging(val) { if (!val) { this.setValues(); } }, firstValue: function firstValue(val) { if (this.range) { this.$emit('input', [this.minValue, this.maxValue]); } else { this.$emit('input', val); } }, secondValue: function secondValue() { if (this.range) { this.$emit('input', [this.minValue, this.maxValue]); } }, min: function min() { this.setValues(); }, max: function max() { this.setValues(); } }, methods: { valueChanged: function valueChanged() { var _this = this; if (this.range) { return ![this.minValue, this.maxValue].every(function (item, index) { return item === _this.oldValue[index]; }); } else { return this.value !== this.oldValue; } }, setValues: function setValues() { if (this.min > this.max) { console.error('[Element Error][Slider]min should not be greater than max.'); return; } var val = this.value; if (this.range && Array.isArray(val)) { if (val[1] < this.min) { this.$emit('input', [this.min, this.min]); } else if (val[0] > this.max) { this.$emit('input', [this.max, this.max]); } else if (val[0] < this.min) { this.$emit('input', [this.min, val[1]]); } else if (val[1] > this.max) { this.$emit('input', [val[0], this.max]); } else { this.firstValue = val[0]; this.secondValue = val[1]; if (this.valueChanged()) { this.dispatch('ElFormItem', 'el.form.change', [this.minValue, this.maxValue]); this.oldValue = val.slice(); } } } else if (!this.range && typeof val === 'number' && !isNaN(val)) { if (val < this.min) { this.$emit('input', this.min); } else if (val > this.max) { this.$emit('input', this.max); } else { this.firstValue = val; if (this.valueChanged()) { this.dispatch('ElFormItem', 'el.form.change', val); this.oldValue = val; } } } }, setPosition: function setPosition(percent) { var targetValue = this.min + percent * (this.max - this.min) / 100; if (!this.range) { this.$refs.button1.setPosition(percent); return; } var button = void 0; if (Math.abs(this.minValue - targetValue) < Math.abs(this.maxValue - targetValue)) { button = this.firstValue < this.secondValue ? 'button1' : 'button2'; } else { button = this.firstValue > this.secondValue ? 'button1' : 'button2'; } this.$refs[button].setPosition(percent); }, onSliderClick: function onSliderClick(event) { if (this.sliderDisabled || this.dragging) return; this.resetSize(); if (this.vertical) { var sliderOffsetBottom = this.$refs.slider.getBoundingClientRect().bottom; this.setPosition((sliderOffsetBottom - event.clientY) / this.sliderSize * 100); } else { var sliderOffsetLeft = this.$refs.slider.getBoundingClientRect().left; this.setPosition((event.clientX - sliderOffsetLeft) / this.sliderSize * 100); } this.emitChange(); }, resetSize: function resetSize() { if (this.$refs.slider) { this.sliderSize = this.$refs.slider['client' + (this.vertical ? 'Height' : 'Width')]; } }, emitChange: function emitChange() { var _this2 = this; this.$nextTick(function () { _this2.$emit('change', _this2.range ? [_this2.minValue, _this2.maxValue] : _this2.value); }); }, getStopStyle: function getStopStyle(position) { return this.vertical ? { 'bottom': position + '%' } : { 'left': position + '%' }; } }, computed: { stops: function stops() { var _this3 = this; if (!this.showStops || this.min > this.max) return []; if (this.step === 0) { false && false; return []; } var stopCount = (this.max - this.min) / this.step; var stepWidth = 100 * this.step / (this.max - this.min); var result = []; for (var i = 1; i < stopCount; i++) { result.push(i * stepWidth); } if (this.range) { return result.filter(function (step) { return step < 100 * (_this3.minValue - _this3.min) / (_this3.max - _this3.min) || step > 100 * (_this3.maxValue - _this3.min) / (_this3.max - _this3.min); }); } else { return result.filter(function (step) { return step > 100 * (_this3.firstValue - _this3.min) / (_this3.max - _this3.min); }); } }, markList: function markList() { var _this4 = this; if (!this.marks) { return []; } var marksKeys = Object.keys(this.marks); return marksKeys.map(parseFloat).sort(function (a, b) { return a - b; }).filter(function (point) { return point <= _this4.max && point >= _this4.min; }).map(function (point) { return { point: point, position: (point - _this4.min) * 100 / (_this4.max - _this4.min), mark: _this4.marks[point] }; }); }, minValue: function minValue() { return Math.min(this.firstValue, this.secondValue); }, maxValue: function maxValue() { return Math.max(this.firstValue, this.secondValue); }, barSize: function barSize() { return this.range ? 100 * (this.maxValue - this.minValue) / (this.max - this.min) + '%' : 100 * (this.firstValue - this.min) / (this.max - this.min) + '%'; }, barStart: function barStart() { return this.range ? 100 * (this.minValue - this.min) / (this.max - this.min) + '%' : '0%'; }, precision: function precision() { var precisions = [this.min, this.max, this.step].map(function (item) { var decimal = ('' + item).split('.')[1]; return decimal ? decimal.length : 0; }); return Math.max.apply(null, precisions); }, runwayStyle: function runwayStyle() { return this.vertical ? { height: this.height } : {}; }, barStyle: function barStyle() { return this.vertical ? { height: this.barSize, bottom: this.barStart } : { width: this.barSize, left: this.barStart }; }, sliderDisabled: function sliderDisabled() { return this.disabled || (this.elForm || {}).disabled; } }, mounted: function mounted() { var valuetext = void 0; if (this.range) { if (Array.isArray(this.value)) { this.firstValue = Math.max(this.min, this.value[0]); this.secondValue = Math.min(this.max, this.value[1]); } else { this.firstValue = this.min; this.secondValue = this.max; } this.oldValue = [this.firstValue, this.secondValue]; valuetext = this.firstValue + '-' + this.secondValue; } else { if (typeof this.value !== 'number' || isNaN(this.value)) { this.firstValue = this.min; } else { this.firstValue = Math.min(this.max, Math.max(this.min, this.value)); } this.oldValue = this.firstValue; valuetext = this.firstValue; } this.$el.setAttribute('aria-valuetext', valuetext); // label screen reader this.$el.setAttribute('aria-label', this.label ? this.label : 'slider between ' + this.min + ' and ' + this.max); this.resetSize(); window.addEventListener('resize', this.resetSize); }, beforeDestroy: function beforeDestroy() { window.removeEventListener('resize', this.resetSize); } }); // CONCATENATED MODULE: ./packages/slider/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_slider_src_mainvue_type_script_lang_js_ = (slider_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/slider/src/main.vue /* normalize component */ var slider_src_main_component = normalizeComponent( packages_slider_src_mainvue_type_script_lang_js_, mainvue_type_template_id_32708644_render, mainvue_type_template_id_32708644_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var slider_src_main_api; } slider_src_main_component.options.__file = "packages/slider/src/main.vue" /* harmony default export */ var slider_src_main = (slider_src_main_component.exports); // CONCATENATED MODULE: ./packages/slider/index.js /* istanbul ignore next */ slider_src_main.install = function (Vue) { Vue.component(slider_src_main.name, slider_src_main); }; /* harmony default export */ var slider = (slider_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/loading/src/loading.vue?vue&type=template&id=eee0a7ac& var loadingvue_type_template_id_eee0a7ac_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-loading-fade" }, on: { "after-leave": _vm.handleAfterLeave } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-loading-mask", class: [_vm.customClass, { "is-fullscreen": _vm.fullscreen }], style: { backgroundColor: _vm.background || "" } }, [ _c("div", { staticClass: "el-loading-spinner" }, [ !_vm.spinner ? _c( "svg", { staticClass: "circular", attrs: { viewBox: "25 25 50 50" } }, [ _c("circle", { staticClass: "path", attrs: { cx: "50", cy: "50", r: "20", fill: "none" } }) ] ) : _c("i", { class: _vm.spinner }), _vm.text ? _c("p", { staticClass: "el-loading-text" }, [ _vm._v(_vm._s(_vm.text)) ]) : _vm._e() ]) ] ) ] ) } var loadingvue_type_template_id_eee0a7ac_staticRenderFns = [] loadingvue_type_template_id_eee0a7ac_render._withStripped = true // CONCATENATED MODULE: ./packages/loading/src/loading.vue?vue&type=template&id=eee0a7ac& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/loading/src/loading.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // /* harmony default export */ var loadingvue_type_script_lang_js_ = ({ data: function data() { return { text: null, spinner: null, background: null, fullscreen: true, visible: false, customClass: '' }; }, methods: { handleAfterLeave: function handleAfterLeave() { this.$emit('after-leave'); }, setText: function setText(text) { this.text = text; } } }); // CONCATENATED MODULE: ./packages/loading/src/loading.vue?vue&type=script&lang=js& /* harmony default export */ var src_loadingvue_type_script_lang_js_ = (loadingvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/loading/src/loading.vue /* normalize component */ var loading_component = normalizeComponent( src_loadingvue_type_script_lang_js_, loadingvue_type_template_id_eee0a7ac_render, loadingvue_type_template_id_eee0a7ac_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var loading_api; } loading_component.options.__file = "packages/loading/src/loading.vue" /* harmony default export */ var loading = (loading_component.exports); // EXTERNAL MODULE: external "element-ui/lib/utils/after-leave" var after_leave_ = __webpack_require__(33); var after_leave_default = /*#__PURE__*/__webpack_require__.n(after_leave_); // CONCATENATED MODULE: ./packages/loading/src/directive.js var Mask = external_vue_default.a.extend(loading); var loadingDirective = {}; loadingDirective.install = function (Vue) { if (Vue.prototype.$isServer) return; var toggleLoading = function toggleLoading(el, binding) { if (binding.value) { Vue.nextTick(function () { if (binding.modifiers.fullscreen) { el.originalPosition = Object(dom_["getStyle"])(document.body, 'position'); el.originalOverflow = Object(dom_["getStyle"])(document.body, 'overflow'); el.maskStyle.zIndex = popup_["PopupManager"].nextZIndex(); Object(dom_["addClass"])(el.mask, 'is-fullscreen'); insertDom(document.body, el, binding); } else { Object(dom_["removeClass"])(el.mask, 'is-fullscreen'); if (binding.modifiers.body) { el.originalPosition = Object(dom_["getStyle"])(document.body, 'position'); ['top', 'left'].forEach(function (property) { var scroll = property === 'top' ? 'scrollTop' : 'scrollLeft'; el.maskStyle[property] = el.getBoundingClientRect()[property] + document.body[scroll] + document.documentElement[scroll] - parseInt(Object(dom_["getStyle"])(document.body, 'margin-' + property), 10) + 'px'; }); ['height', 'width'].forEach(function (property) { el.maskStyle[property] = el.getBoundingClientRect()[property] + 'px'; }); insertDom(document.body, el, binding); } else { el.originalPosition = Object(dom_["getStyle"])(el, 'position'); insertDom(el, el, binding); } } }); } else { after_leave_default()(el.instance, function (_) { if (!el.instance.hiding) return; el.domVisible = false; var target = binding.modifiers.fullscreen || binding.modifiers.body ? document.body : el; Object(dom_["removeClass"])(target, 'el-loading-parent--relative'); Object(dom_["removeClass"])(target, 'el-loading-parent--hidden'); el.instance.hiding = false; }, 300, true); el.instance.visible = false; el.instance.hiding = true; } }; var insertDom = function insertDom(parent, el, binding) { if (!el.domVisible && Object(dom_["getStyle"])(el, 'display') !== 'none' && Object(dom_["getStyle"])(el, 'visibility') !== 'hidden') { Object.keys(el.maskStyle).forEach(function (property) { el.mask.style[property] = el.maskStyle[property]; }); if (el.originalPosition !== 'absolute' && el.originalPosition !== 'fixed') { Object(dom_["addClass"])(parent, 'el-loading-parent--relative'); } if (binding.modifiers.fullscreen && binding.modifiers.lock) { Object(dom_["addClass"])(parent, 'el-loading-parent--hidden'); } el.domVisible = true; parent.appendChild(el.mask); Vue.nextTick(function () { if (el.instance.hiding) { el.instance.$emit('after-leave'); } else { el.instance.visible = true; } }); el.domInserted = true; } else if (el.domVisible && el.instance.hiding === true) { el.instance.visible = true; el.instance.hiding = false; } }; Vue.directive('loading', { bind: function bind(el, binding, vnode) { var textExr = el.getAttribute('element-loading-text'); var spinnerExr = el.getAttribute('element-loading-spinner'); var backgroundExr = el.getAttribute('element-loading-background'); var customClassExr = el.getAttribute('element-loading-custom-class'); var vm = vnode.context; var mask = new Mask({ el: document.createElement('div'), data: { text: vm && vm[textExr] || textExr, spinner: vm && vm[spinnerExr] || spinnerExr, background: vm && vm[backgroundExr] || backgroundExr, customClass: vm && vm[customClassExr] || customClassExr, fullscreen: !!binding.modifiers.fullscreen } }); el.instance = mask; el.mask = mask.$el; el.maskStyle = {}; binding.value && toggleLoading(el, binding); }, update: function update(el, binding) { el.instance.setText(el.getAttribute('element-loading-text')); if (binding.oldValue !== binding.value) { toggleLoading(el, binding); } }, unbind: function unbind(el, binding) { if (el.domInserted) { el.mask && el.mask.parentNode && el.mask.parentNode.removeChild(el.mask); toggleLoading(el, { value: false, modifiers: binding.modifiers }); } el.instance && el.instance.$destroy(); } }); }; /* harmony default export */ var src_directive = (loadingDirective); // CONCATENATED MODULE: ./packages/loading/src/index.js var LoadingConstructor = external_vue_default.a.extend(loading); var src_defaults = { text: null, fullscreen: true, body: false, lock: false, customClass: '' }; var fullscreenLoading = void 0; LoadingConstructor.prototype.originalPosition = ''; LoadingConstructor.prototype.originalOverflow = ''; LoadingConstructor.prototype.close = function () { var _this = this; if (this.fullscreen) { fullscreenLoading = undefined; } after_leave_default()(this, function (_) { var target = _this.fullscreen || _this.body ? document.body : _this.target; Object(dom_["removeClass"])(target, 'el-loading-parent--relative'); Object(dom_["removeClass"])(target, 'el-loading-parent--hidden'); if (_this.$el && _this.$el.parentNode) { _this.$el.parentNode.removeChild(_this.$el); } _this.$destroy(); }, 300); this.visible = false; }; var src_addStyle = function addStyle(options, parent, instance) { var maskStyle = {}; if (options.fullscreen) { instance.originalPosition = Object(dom_["getStyle"])(document.body, 'position'); instance.originalOverflow = Object(dom_["getStyle"])(document.body, 'overflow'); maskStyle.zIndex = popup_["PopupManager"].nextZIndex(); } else if (options.body) { instance.originalPosition = Object(dom_["getStyle"])(document.body, 'position'); ['top', 'left'].forEach(function (property) { var scroll = property === 'top' ? 'scrollTop' : 'scrollLeft'; maskStyle[property] = options.target.getBoundingClientRect()[property] + document.body[scroll] + document.documentElement[scroll] + 'px'; }); ['height', 'width'].forEach(function (property) { maskStyle[property] = options.target.getBoundingClientRect()[property] + 'px'; }); } else { instance.originalPosition = Object(dom_["getStyle"])(parent, 'position'); } Object.keys(maskStyle).forEach(function (property) { instance.$el.style[property] = maskStyle[property]; }); }; var src_Loading = function Loading() { var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; if (external_vue_default.a.prototype.$isServer) return; options = merge_default()({}, src_defaults, options); if (typeof options.target === 'string') { options.target = document.querySelector(options.target); } options.target = options.target || document.body; if (options.target !== document.body) { options.fullscreen = false; } else { options.body = true; } if (options.fullscreen && fullscreenLoading) { return fullscreenLoading; } var parent = options.body ? document.body : options.target; var instance = new LoadingConstructor({ el: document.createElement('div'), data: options }); src_addStyle(options, parent, instance); if (instance.originalPosition !== 'absolute' && instance.originalPosition !== 'fixed') { Object(dom_["addClass"])(parent, 'el-loading-parent--relative'); } if (options.fullscreen && options.lock) { Object(dom_["addClass"])(parent, 'el-loading-parent--hidden'); } parent.appendChild(instance.$el); external_vue_default.a.nextTick(function () { instance.visible = true; }); if (options.fullscreen) { fullscreenLoading = instance; } return instance; }; /* harmony default export */ var src = (src_Loading); // CONCATENATED MODULE: ./packages/loading/index.js /* harmony default export */ var packages_loading = ({ install: function install(Vue) { Vue.use(src_directive); Vue.prototype.$loading = src; }, directive: src_directive, service: src }); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/icon/src/icon.vue?vue&type=template&id=cb3fe7f4& var iconvue_type_template_id_cb3fe7f4_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("i", { class: "el-icon-" + _vm.name }) } var iconvue_type_template_id_cb3fe7f4_staticRenderFns = [] iconvue_type_template_id_cb3fe7f4_render._withStripped = true // CONCATENATED MODULE: ./packages/icon/src/icon.vue?vue&type=template&id=cb3fe7f4& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/icon/src/icon.vue?vue&type=script&lang=js& // // // // /* harmony default export */ var iconvue_type_script_lang_js_ = ({ name: 'ElIcon', props: { name: String } }); // CONCATENATED MODULE: ./packages/icon/src/icon.vue?vue&type=script&lang=js& /* harmony default export */ var src_iconvue_type_script_lang_js_ = (iconvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/icon/src/icon.vue /* normalize component */ var icon_component = normalizeComponent( src_iconvue_type_script_lang_js_, iconvue_type_template_id_cb3fe7f4_render, iconvue_type_template_id_cb3fe7f4_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var icon_api; } icon_component.options.__file = "packages/icon/src/icon.vue" /* harmony default export */ var icon = (icon_component.exports); // CONCATENATED MODULE: ./packages/icon/index.js /* istanbul ignore next */ icon.install = function (Vue) { Vue.component(icon.name, icon); }; /* harmony default export */ var packages_icon = (icon); // CONCATENATED MODULE: ./packages/row/src/row.js /* harmony default export */ var src_row = ({ name: 'ElRow', componentName: 'ElRow', props: { tag: { type: String, default: 'div' }, gutter: Number, type: String, justify: { type: String, default: 'start' }, align: { type: String, default: 'top' } }, computed: { style: function style() { var ret = {}; if (this.gutter) { ret.marginLeft = '-' + this.gutter / 2 + 'px'; ret.marginRight = ret.marginLeft; } return ret; } }, render: function render(h) { return h(this.tag, { class: ['el-row', this.justify !== 'start' ? 'is-justify-' + this.justify : '', this.align !== 'top' ? 'is-align-' + this.align : '', { 'el-row--flex': this.type === 'flex' }], style: this.style }, this.$slots.default); } }); // CONCATENATED MODULE: ./packages/row/index.js /* istanbul ignore next */ src_row.install = function (Vue) { Vue.component(src_row.name, src_row); }; /* harmony default export */ var packages_row = (src_row); // CONCATENATED MODULE: ./packages/col/src/col.js var col_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; }; /* harmony default export */ var col = ({ name: 'ElCol', props: { span: { type: Number, default: 24 }, tag: { type: String, default: 'div' }, offset: Number, pull: Number, push: Number, xs: [Number, Object], sm: [Number, Object], md: [Number, Object], lg: [Number, Object], xl: [Number, Object] }, computed: { gutter: function gutter() { var parent = this.$parent; while (parent && parent.$options.componentName !== 'ElRow') { parent = parent.$parent; } return parent ? parent.gutter : 0; } }, render: function render(h) { var _this = this; var classList = []; var style = {}; if (this.gutter) { style.paddingLeft = this.gutter / 2 + 'px'; style.paddingRight = style.paddingLeft; } ['span', 'offset', 'pull', 'push'].forEach(function (prop) { if (_this[prop] || _this[prop] === 0) { classList.push(prop !== 'span' ? 'el-col-' + prop + '-' + _this[prop] : 'el-col-' + _this[prop]); } }); ['xs', 'sm', 'md', 'lg', 'xl'].forEach(function (size) { if (typeof _this[size] === 'number') { classList.push('el-col-' + size + '-' + _this[size]); } else if (col_typeof(_this[size]) === 'object') { var props = _this[size]; Object.keys(props).forEach(function (prop) { classList.push(prop !== 'span' ? 'el-col-' + size + '-' + prop + '-' + props[prop] : 'el-col-' + size + '-' + props[prop]); }); } }); return h(this.tag, { class: ['el-col', classList], style: style }, this.$slots.default); } }); // CONCATENATED MODULE: ./packages/col/index.js /* istanbul ignore next */ col.install = function (Vue) { Vue.component(col.name, col); }; /* harmony default export */ var packages_col = (col); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/upload-list.vue?vue&type=template&id=173fedf5& var upload_listvue_type_template_id_173fedf5_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition-group", { class: [ "el-upload-list", "el-upload-list--" + _vm.listType, { "is-disabled": _vm.disabled } ], attrs: { tag: "ul", name: "el-list" } }, _vm._l(_vm.files, function(file) { return _c( "li", { key: file.uid, class: [ "el-upload-list__item", "is-" + file.status, _vm.focusing ? "focusing" : "" ], attrs: { tabindex: "0" }, on: { keydown: function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "delete", [8, 46], $event.key, [ "Backspace", "Delete", "Del" ]) ) { return null } !_vm.disabled && _vm.$emit("remove", file) }, focus: function($event) { _vm.focusing = true }, blur: function($event) { _vm.focusing = false }, click: function($event) { _vm.focusing = false } } }, [ _vm._t( "default", [ file.status !== "uploading" && ["picture-card", "picture"].indexOf(_vm.listType) > -1 ? _c("img", { staticClass: "el-upload-list__item-thumbnail", attrs: { src: file.url, alt: "" } }) : _vm._e(), _c( "a", { staticClass: "el-upload-list__item-name", on: { click: function($event) { _vm.handleClick(file) } } }, [ _c("i", { staticClass: "el-icon-document" }), _vm._v(_vm._s(file.name) + "\n ") ] ), _c( "label", { staticClass: "el-upload-list__item-status-label" }, [ _c("i", { class: { "el-icon-upload-success": true, "el-icon-circle-check": _vm.listType === "text", "el-icon-check": ["picture-card", "picture"].indexOf(_vm.listType) > -1 } }) ] ), !_vm.disabled ? _c("i", { staticClass: "el-icon-close", on: { click: function($event) { _vm.$emit("remove", file) } } }) : _vm._e(), !_vm.disabled ? _c("i", { staticClass: "el-icon-close-tip" }, [ _vm._v(_vm._s(_vm.t("el.upload.deleteTip"))) ]) : _vm._e(), file.status === "uploading" ? _c("el-progress", { attrs: { type: _vm.listType === "picture-card" ? "circle" : "line", "stroke-width": _vm.listType === "picture-card" ? 6 : 2, percentage: _vm.parsePercentage(file.percentage) } }) : _vm._e(), _vm.listType === "picture-card" ? _c("span", { staticClass: "el-upload-list__item-actions" }, [ _vm.handlePreview && _vm.listType === "picture-card" ? _c( "span", { staticClass: "el-upload-list__item-preview", on: { click: function($event) { _vm.handlePreview(file) } } }, [_c("i", { staticClass: "el-icon-zoom-in" })] ) : _vm._e(), !_vm.disabled ? _c( "span", { staticClass: "el-upload-list__item-delete", on: { click: function($event) { _vm.$emit("remove", file) } } }, [_c("i", { staticClass: "el-icon-delete" })] ) : _vm._e() ]) : _vm._e() ], { file: file } ) ], 2 ) }), 0 ) } var upload_listvue_type_template_id_173fedf5_staticRenderFns = [] upload_listvue_type_template_id_173fedf5_render._withStripped = true // CONCATENATED MODULE: ./packages/upload/src/upload-list.vue?vue&type=template&id=173fedf5& // EXTERNAL MODULE: external "element-ui/lib/progress" var progress_ = __webpack_require__(34); var progress_default = /*#__PURE__*/__webpack_require__.n(progress_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/upload-list.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var upload_listvue_type_script_lang_js_ = ({ name: 'ElUploadList', mixins: [locale_default.a], data: function data() { return { focusing: false }; }, components: { ElProgress: progress_default.a }, props: { files: { type: Array, default: function _default() { return []; } }, disabled: { type: Boolean, default: false }, handlePreview: Function, listType: String }, methods: { parsePercentage: function parsePercentage(val) { return parseInt(val, 10); }, handleClick: function handleClick(file) { this.handlePreview && this.handlePreview(file); } } }); // CONCATENATED MODULE: ./packages/upload/src/upload-list.vue?vue&type=script&lang=js& /* harmony default export */ var src_upload_listvue_type_script_lang_js_ = (upload_listvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/upload/src/upload-list.vue /* normalize component */ var upload_list_component = normalizeComponent( src_upload_listvue_type_script_lang_js_, upload_listvue_type_template_id_173fedf5_render, upload_listvue_type_template_id_173fedf5_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var upload_list_api; } upload_list_component.options.__file = "packages/upload/src/upload-list.vue" /* harmony default export */ var upload_list = (upload_list_component.exports); // EXTERNAL MODULE: external "babel-helper-vue-jsx-merge-props" var external_babel_helper_vue_jsx_merge_props_ = __webpack_require__(24); var external_babel_helper_vue_jsx_merge_props_default = /*#__PURE__*/__webpack_require__.n(external_babel_helper_vue_jsx_merge_props_); // CONCATENATED MODULE: ./packages/upload/src/ajax.js function getError(action, option, xhr) { var msg = void 0; if (xhr.response) { msg = '' + (xhr.response.error || xhr.response); } else if (xhr.responseText) { msg = '' + xhr.responseText; } else { msg = 'fail to post ' + action + ' ' + xhr.status; } var err = new Error(msg); err.status = xhr.status; err.method = 'post'; err.url = action; return err; } function getBody(xhr) { var text = xhr.responseText || xhr.response; if (!text) { return text; } try { return JSON.parse(text); } catch (e) { return text; } } function upload(option) { if (typeof XMLHttpRequest === 'undefined') { return; } var xhr = new XMLHttpRequest(); var action = option.action; if (xhr.upload) { xhr.upload.onprogress = function progress(e) { if (e.total > 0) { e.percent = e.loaded / e.total * 100; } option.onProgress(e); }; } var formData = new FormData(); if (option.data) { Object.keys(option.data).forEach(function (key) { formData.append(key, option.data[key]); }); } formData.append(option.filename, option.file, option.file.name); xhr.onerror = function error(e) { option.onError(e); }; xhr.onload = function onload() { if (xhr.status < 200 || xhr.status >= 300) { return option.onError(getError(action, option, xhr)); } option.onSuccess(getBody(xhr)); }; xhr.open('post', action, true); if (option.withCredentials && 'withCredentials' in xhr) { xhr.withCredentials = true; } var headers = option.headers || {}; for (var item in headers) { if (headers.hasOwnProperty(item) && headers[item] !== null) { xhr.setRequestHeader(item, headers[item]); } } xhr.send(formData); return xhr; } // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/upload-dragger.vue?vue&type=template&id=7ebbf219& var upload_draggervue_type_template_id_7ebbf219_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-upload-dragger", class: { "is-dragover": _vm.dragover }, on: { drop: function($event) { $event.preventDefault() return _vm.onDrop($event) }, dragover: function($event) { $event.preventDefault() return _vm.onDragover($event) }, dragleave: function($event) { $event.preventDefault() _vm.dragover = false } } }, [_vm._t("default")], 2 ) } var upload_draggervue_type_template_id_7ebbf219_staticRenderFns = [] upload_draggervue_type_template_id_7ebbf219_render._withStripped = true // CONCATENATED MODULE: ./packages/upload/src/upload-dragger.vue?vue&type=template&id=7ebbf219& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/upload-dragger.vue?vue&type=script&lang=js& // // // // // // // // // // // // // /* harmony default export */ var upload_draggervue_type_script_lang_js_ = ({ name: 'ElUploadDrag', props: { disabled: Boolean }, inject: { uploader: { default: '' } }, data: function data() { return { dragover: false }; }, methods: { onDragover: function onDragover() { if (!this.disabled) { this.dragover = true; } }, onDrop: function onDrop(e) { if (this.disabled || !this.uploader) return; var accept = this.uploader.accept; this.dragover = false; if (!accept) { this.$emit('file', e.dataTransfer.files); return; } this.$emit('file', [].slice.call(e.dataTransfer.files).filter(function (file) { var type = file.type, name = file.name; var extension = name.indexOf('.') > -1 ? '.' + name.split('.').pop() : ''; var baseType = type.replace(/\/.*$/, ''); return accept.split(',').map(function (type) { return type.trim(); }).filter(function (type) { return type; }).some(function (acceptedType) { if (/\..+$/.test(acceptedType)) { return extension === acceptedType; } if (/\/\*$/.test(acceptedType)) { return baseType === acceptedType.replace(/\/\*$/, ''); } if (/^[^\/]+\/[^\/]+$/.test(acceptedType)) { return type === acceptedType; } return false; }); })); } } }); // CONCATENATED MODULE: ./packages/upload/src/upload-dragger.vue?vue&type=script&lang=js& /* harmony default export */ var src_upload_draggervue_type_script_lang_js_ = (upload_draggervue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/upload/src/upload-dragger.vue /* normalize component */ var upload_dragger_component = normalizeComponent( src_upload_draggervue_type_script_lang_js_, upload_draggervue_type_template_id_7ebbf219_render, upload_draggervue_type_template_id_7ebbf219_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var upload_dragger_api; } upload_dragger_component.options.__file = "packages/upload/src/upload-dragger.vue" /* harmony default export */ var upload_dragger = (upload_dragger_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/upload.vue?vue&type=script&lang=js& /* harmony default export */ var uploadvue_type_script_lang_js_ = ({ inject: ['uploader'], components: { UploadDragger: upload_dragger }, props: { type: String, action: { type: String, required: true }, name: { type: String, default: 'file' }, data: Object, headers: Object, withCredentials: Boolean, multiple: Boolean, accept: String, onStart: Function, onProgress: Function, onSuccess: Function, onError: Function, beforeUpload: Function, drag: Boolean, onPreview: { type: Function, default: function _default() {} }, onRemove: { type: Function, default: function _default() {} }, fileList: Array, autoUpload: Boolean, listType: String, httpRequest: { type: Function, default: upload }, disabled: Boolean, limit: Number, onExceed: Function }, data: function data() { return { mouseover: false, reqs: {} }; }, methods: { isImage: function isImage(str) { return str.indexOf('image') !== -1; }, handleChange: function handleChange(ev) { var files = ev.target.files; if (!files) return; this.uploadFiles(files); }, uploadFiles: function uploadFiles(files) { var _this = this; if (this.limit && this.fileList.length + files.length > this.limit) { this.onExceed && this.onExceed(files, this.fileList); return; } var postFiles = Array.prototype.slice.call(files); if (!this.multiple) { postFiles = postFiles.slice(0, 1); } if (postFiles.length === 0) { return; } postFiles.forEach(function (rawFile) { _this.onStart(rawFile); if (_this.autoUpload) _this.upload(rawFile); }); }, upload: function upload(rawFile) { var _this2 = this; this.$refs.input.value = null; if (!this.beforeUpload) { return this.post(rawFile); } var before = this.beforeUpload(rawFile); if (before && before.then) { before.then(function (processedFile) { var fileType = Object.prototype.toString.call(processedFile); if (fileType === '[object File]' || fileType === '[object Blob]') { if (fileType === '[object Blob]') { processedFile = new File([processedFile], rawFile.name, { type: rawFile.type }); } for (var p in rawFile) { if (rawFile.hasOwnProperty(p)) { processedFile[p] = rawFile[p]; } } _this2.post(processedFile); } else { _this2.post(rawFile); } }, function () { _this2.onRemove(null, rawFile); }); } else if (before !== false) { this.post(rawFile); } else { this.onRemove(null, rawFile); } }, abort: function abort(file) { var reqs = this.reqs; if (file) { var uid = file; if (file.uid) uid = file.uid; if (reqs[uid]) { reqs[uid].abort(); } } else { Object.keys(reqs).forEach(function (uid) { if (reqs[uid]) reqs[uid].abort(); delete reqs[uid]; }); } }, post: function post(rawFile) { var _this3 = this; var uid = rawFile.uid; var options = { headers: this.headers, withCredentials: this.withCredentials, file: rawFile, data: this.data, filename: this.name, action: this.action, onProgress: function onProgress(e) { _this3.onProgress(e, rawFile); }, onSuccess: function onSuccess(res) { _this3.onSuccess(res, rawFile); delete _this3.reqs[uid]; }, onError: function onError(err) { _this3.onError(err, rawFile); delete _this3.reqs[uid]; } }; var req = this.httpRequest(options); this.reqs[uid] = req; if (req && req.then) { req.then(options.onSuccess, options.onError); } }, handleClick: function handleClick() { if (!this.disabled) { this.$refs.input.value = null; this.$refs.input.click(); } }, handleKeydown: function handleKeydown(e) { if (e.target !== e.currentTarget) return; if (e.keyCode === 13 || e.keyCode === 32) { this.handleClick(); } } }, render: function render(h) { var handleClick = this.handleClick, drag = this.drag, name = this.name, handleChange = this.handleChange, multiple = this.multiple, accept = this.accept, listType = this.listType, uploadFiles = this.uploadFiles, disabled = this.disabled, handleKeydown = this.handleKeydown; var data = { class: { 'el-upload': true }, on: { click: handleClick, keydown: handleKeydown } }; data.class['el-upload--' + listType] = true; return h( 'div', external_babel_helper_vue_jsx_merge_props_default()([data, { attrs: { tabindex: '0' } }]), [drag ? h( 'upload-dragger', { attrs: { disabled: disabled }, on: { 'file': uploadFiles } }, [this.$slots.default] ) : this.$slots.default, h('input', { 'class': 'el-upload__input', attrs: { type: 'file', name: name, multiple: multiple, accept: accept }, ref: 'input', on: { 'change': handleChange } })] ); } }); // CONCATENATED MODULE: ./packages/upload/src/upload.vue?vue&type=script&lang=js& /* harmony default export */ var src_uploadvue_type_script_lang_js_ = (uploadvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/upload/src/upload.vue var upload_render, upload_staticRenderFns /* normalize component */ var upload_component = normalizeComponent( src_uploadvue_type_script_lang_js_, upload_render, upload_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var upload_api; } upload_component.options.__file = "packages/upload/src/upload.vue" /* harmony default export */ var src_upload = (upload_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/upload/src/index.vue?vue&type=script&lang=js& function srcvue_type_script_lang_js_noop() {} /* harmony default export */ var srcvue_type_script_lang_js_ = ({ name: 'ElUpload', mixins: [migrating_default.a], components: { ElProgress: progress_default.a, UploadList: upload_list, Upload: src_upload }, provide: function provide() { return { uploader: this }; }, inject: { elForm: { default: '' } }, props: { action: { type: String, required: true }, headers: { type: Object, default: function _default() { return {}; } }, data: Object, multiple: Boolean, name: { type: String, default: 'file' }, drag: Boolean, dragger: Boolean, withCredentials: Boolean, showFileList: { type: Boolean, default: true }, accept: String, type: { type: String, default: 'select' }, beforeUpload: Function, beforeRemove: Function, onRemove: { type: Function, default: srcvue_type_script_lang_js_noop }, onChange: { type: Function, default: srcvue_type_script_lang_js_noop }, onPreview: { type: Function }, onSuccess: { type: Function, default: srcvue_type_script_lang_js_noop }, onProgress: { type: Function, default: srcvue_type_script_lang_js_noop }, onError: { type: Function, default: srcvue_type_script_lang_js_noop }, fileList: { type: Array, default: function _default() { return []; } }, autoUpload: { type: Boolean, default: true }, listType: { type: String, default: 'text' // text,picture,picture-card }, httpRequest: Function, disabled: Boolean, limit: Number, onExceed: { type: Function, default: srcvue_type_script_lang_js_noop } }, data: function data() { return { uploadFiles: [], dragOver: false, draging: false, tempIndex: 1 }; }, computed: { uploadDisabled: function uploadDisabled() { return this.disabled || (this.elForm || {}).disabled; } }, watch: { listType: function listType(type) { if (type === 'picture-card' || type === 'picture') { this.uploadFiles = this.uploadFiles.map(function (file) { if (!file.url && file.raw) { try { file.url = URL.createObjectURL(file.raw); } catch (err) { console.error('[Element Error][Upload]', err); } } return file; }); } }, fileList: { immediate: true, handler: function handler(fileList) { var _this = this; this.uploadFiles = fileList.map(function (item) { item.uid = item.uid || Date.now() + _this.tempIndex++; item.status = item.status || 'success'; return item; }); } } }, methods: { handleStart: function handleStart(rawFile) { rawFile.uid = Date.now() + this.tempIndex++; var file = { status: 'ready', name: rawFile.name, size: rawFile.size, percentage: 0, uid: rawFile.uid, raw: rawFile }; if (this.listType === 'picture-card' || this.listType === 'picture') { try { file.url = URL.createObjectURL(rawFile); } catch (err) { console.error('[Element Error][Upload]', err); return; } } this.uploadFiles.push(file); this.onChange(file, this.uploadFiles); }, handleProgress: function handleProgress(ev, rawFile) { var file = this.getFile(rawFile); this.onProgress(ev, file, this.uploadFiles); file.status = 'uploading'; file.percentage = ev.percent || 0; }, handleSuccess: function handleSuccess(res, rawFile) { var file = this.getFile(rawFile); if (file) { file.status = 'success'; file.response = res; this.onSuccess(res, file, this.uploadFiles); this.onChange(file, this.uploadFiles); } }, handleError: function handleError(err, rawFile) { var file = this.getFile(rawFile); var fileList = this.uploadFiles; file.status = 'fail'; fileList.splice(fileList.indexOf(file), 1); this.onError(err, file, this.uploadFiles); this.onChange(file, this.uploadFiles); }, handleRemove: function handleRemove(file, raw) { var _this2 = this; if (raw) { file = this.getFile(raw); } var doRemove = function doRemove() { _this2.abort(file); var fileList = _this2.uploadFiles; fileList.splice(fileList.indexOf(file), 1); _this2.onRemove(file, fileList); }; if (!this.beforeRemove) { doRemove(); } else if (typeof this.beforeRemove === 'function') { var before = this.beforeRemove(file, this.uploadFiles); if (before && before.then) { before.then(function () { doRemove(); }, srcvue_type_script_lang_js_noop); } else if (before !== false) { doRemove(); } } }, getFile: function getFile(rawFile) { var fileList = this.uploadFiles; var target = void 0; fileList.every(function (item) { target = rawFile.uid === item.uid ? item : null; return !target; }); return target; }, abort: function abort(file) { this.$refs['upload-inner'].abort(file); }, clearFiles: function clearFiles() { this.uploadFiles = []; }, submit: function submit() { var _this3 = this; this.uploadFiles.filter(function (file) { return file.status === 'ready'; }).forEach(function (file) { _this3.$refs['upload-inner'].upload(file.raw); }); }, getMigratingConfig: function getMigratingConfig() { return { props: { 'default-file-list': 'default-file-list is renamed to file-list.', 'show-upload-list': 'show-upload-list is renamed to show-file-list.', 'thumbnail-mode': 'thumbnail-mode has been deprecated, you can implement the same effect according to this case: http://element.eleme.io/#/zh-CN/component/upload#yong-hu-tou-xiang-shang-chuan' } }; } }, beforeDestroy: function beforeDestroy() { this.uploadFiles.forEach(function (file) { if (file.url && file.url.indexOf('blob:') === 0) { URL.revokeObjectURL(file.url); } }); }, render: function render(h) { var _this4 = this; var uploadList = void 0; if (this.showFileList) { uploadList = h( upload_list, { attrs: { disabled: this.uploadDisabled, listType: this.listType, files: this.uploadFiles, handlePreview: this.onPreview }, on: { 'remove': this.handleRemove } }, [function (props) { if (_this4.$scopedSlots.file) { return _this4.$scopedSlots.file({ file: props.file }); } }] ); } var uploadData = { props: { type: this.type, drag: this.drag, action: this.action, multiple: this.multiple, 'before-upload': this.beforeUpload, 'with-credentials': this.withCredentials, headers: this.headers, name: this.name, data: this.data, accept: this.accept, fileList: this.uploadFiles, autoUpload: this.autoUpload, listType: this.listType, disabled: this.uploadDisabled, limit: this.limit, 'on-exceed': this.onExceed, 'on-start': this.handleStart, 'on-progress': this.handleProgress, 'on-success': this.handleSuccess, 'on-error': this.handleError, 'on-preview': this.onPreview, 'on-remove': this.handleRemove, 'http-request': this.httpRequest }, ref: 'upload-inner' }; var trigger = this.$slots.trigger || this.$slots.default; var uploadComponent = h( 'upload', uploadData, [trigger] ); return h('div', [this.listType === 'picture-card' ? uploadList : '', this.$slots.trigger ? [uploadComponent, this.$slots.default] : uploadComponent, this.$slots.tip, this.listType !== 'picture-card' ? uploadList : '']); } }); // CONCATENATED MODULE: ./packages/upload/src/index.vue?vue&type=script&lang=js& /* harmony default export */ var upload_srcvue_type_script_lang_js_ = (srcvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/upload/src/index.vue var src_render, src_staticRenderFns /* normalize component */ var upload_src_component = normalizeComponent( upload_srcvue_type_script_lang_js_, src_render, src_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var src_api; } upload_src_component.options.__file = "packages/upload/src/index.vue" /* harmony default export */ var upload_src = (upload_src_component.exports); // CONCATENATED MODULE: ./packages/upload/index.js /* istanbul ignore next */ upload_src.install = function (Vue) { Vue.component(upload_src.name, upload_src); }; /* harmony default export */ var packages_upload = (upload_src); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/progress/src/progress.vue?vue&type=template&id=229ee406& var progressvue_type_template_id_229ee406_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-progress", class: [ "el-progress--" + _vm.type, _vm.status ? "is-" + _vm.status : "", { "el-progress--without-text": !_vm.showText, "el-progress--text-inside": _vm.textInside } ], attrs: { role: "progressbar", "aria-valuenow": _vm.percentage, "aria-valuemin": "0", "aria-valuemax": "100" } }, [ _vm.type === "line" ? _c("div", { staticClass: "el-progress-bar" }, [ _c( "div", { staticClass: "el-progress-bar__outer", style: { height: _vm.strokeWidth + "px" } }, [ _c( "div", { staticClass: "el-progress-bar__inner", style: _vm.barStyle }, [ _vm.showText && _vm.textInside ? _c( "div", { staticClass: "el-progress-bar__innerText" }, [_vm._v(_vm._s(_vm.content))] ) : _vm._e() ] ) ] ) ]) : _c( "div", { staticClass: "el-progress-circle", style: { height: _vm.width + "px", width: _vm.width + "px" } }, [ _c("svg", { attrs: { viewBox: "0 0 100 100" } }, [ _c("path", { staticClass: "el-progress-circle__track", style: _vm.trailPathStyle, attrs: { d: _vm.trackPath, stroke: "#e5e9f2", "stroke-width": _vm.relativeStrokeWidth, fill: "none" } }), _c("path", { staticClass: "el-progress-circle__path", style: _vm.circlePathStyle, attrs: { d: _vm.trackPath, stroke: _vm.stroke, fill: "none", "stroke-linecap": _vm.strokeLinecap, "stroke-width": _vm.percentage ? _vm.relativeStrokeWidth : 0 } }) ]) ] ), _vm.showText && !_vm.textInside ? _c( "div", { staticClass: "el-progress__text", style: { fontSize: _vm.progressTextSize + "px" } }, [ !_vm.status ? [_vm._v(_vm._s(_vm.content))] : _c("i", { class: _vm.iconClass }) ], 2 ) : _vm._e() ] ) } var progressvue_type_template_id_229ee406_staticRenderFns = [] progressvue_type_template_id_229ee406_render._withStripped = true // CONCATENATED MODULE: ./packages/progress/src/progress.vue?vue&type=template&id=229ee406& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/progress/src/progress.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var progressvue_type_script_lang_js_ = ({ name: 'ElProgress', props: { type: { type: String, default: 'line', validator: function validator(val) { return ['line', 'circle', 'dashboard'].indexOf(val) > -1; } }, percentage: { type: Number, default: 0, required: true, validator: function validator(val) { return val >= 0 && val <= 100; } }, status: { type: String, validator: function validator(val) { return ['success', 'exception', 'warning'].indexOf(val) > -1; } }, strokeWidth: { type: Number, default: 6 }, strokeLinecap: { type: String, default: 'round' }, textInside: { type: Boolean, default: false }, width: { type: Number, default: 126 }, showText: { type: Boolean, default: true }, color: { type: [String, Array, Function], default: '' }, format: Function }, computed: { barStyle: function barStyle() { var style = {}; style.width = this.percentage + '%'; style.backgroundColor = this.getCurrentColor(this.percentage); return style; }, relativeStrokeWidth: function relativeStrokeWidth() { return (this.strokeWidth / this.width * 100).toFixed(1); }, radius: function radius() { if (this.type === 'circle' || this.type === 'dashboard') { return parseInt(50 - parseFloat(this.relativeStrokeWidth) / 2, 10); } else { return 0; } }, trackPath: function trackPath() { var radius = this.radius; var isDashboard = this.type === 'dashboard'; return '\n M 50 50\n m 0 ' + (isDashboard ? '' : '-') + radius + '\n a ' + radius + ' ' + radius + ' 0 1 1 0 ' + (isDashboard ? '-' : '') + radius * 2 + '\n a ' + radius + ' ' + radius + ' 0 1 1 0 ' + (isDashboard ? '' : '-') + radius * 2 + '\n '; }, perimeter: function perimeter() { return 2 * Math.PI * this.radius; }, rate: function rate() { return this.type === 'dashboard' ? 0.75 : 1; }, strokeDashoffset: function strokeDashoffset() { var offset = -1 * this.perimeter * (1 - this.rate) / 2; return offset + 'px'; }, trailPathStyle: function trailPathStyle() { return { strokeDasharray: this.perimeter * this.rate + 'px, ' + this.perimeter + 'px', strokeDashoffset: this.strokeDashoffset }; }, circlePathStyle: function circlePathStyle() { return { strokeDasharray: this.perimeter * this.rate * (this.percentage / 100) + 'px, ' + this.perimeter + 'px', strokeDashoffset: this.strokeDashoffset, transition: 'stroke-dasharray 0.6s ease 0s, stroke 0.6s ease' }; }, stroke: function stroke() { var ret = void 0; if (this.color) { ret = this.getCurrentColor(this.percentage); } else { switch (this.status) { case 'success': ret = '#13ce66'; break; case 'exception': ret = '#ff4949'; break; case 'warning': ret = '#e6a23c'; break; default: ret = '#20a0ff'; } } return ret; }, iconClass: function iconClass() { if (this.status === 'warning') { return 'el-icon-warning'; } if (this.type === 'line') { return this.status === 'success' ? 'el-icon-circle-check' : 'el-icon-circle-close'; } else { return this.status === 'success' ? 'el-icon-check' : 'el-icon-close'; } }, progressTextSize: function progressTextSize() { return this.type === 'line' ? 12 + this.strokeWidth * 0.4 : this.width * 0.111111 + 2; }, content: function content() { if (typeof this.format === 'function') { return this.format(this.percentage) || ''; } else { return this.percentage + '%'; } } }, methods: { getCurrentColor: function getCurrentColor(percentage) { if (typeof this.color === 'function') { return this.color(percentage); } else if (typeof this.color === 'string') { return this.color; } else { return this.getLevelColor(percentage); } }, getLevelColor: function getLevelColor(percentage) { var colorArray = this.getColorArray().sort(function (a, b) { return a.percentage - b.percentage; }); for (var i = 0; i < colorArray.length; i++) { if (colorArray[i].percentage > percentage) { return colorArray[i].color; } } return colorArray[colorArray.length - 1].color; }, getColorArray: function getColorArray() { var color = this.color; var span = 100 / color.length; return color.map(function (seriesColor, index) { if (typeof seriesColor === 'string') { return { color: seriesColor, progress: (index + 1) * span }; } return seriesColor; }); } } }); // CONCATENATED MODULE: ./packages/progress/src/progress.vue?vue&type=script&lang=js& /* harmony default export */ var src_progressvue_type_script_lang_js_ = (progressvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/progress/src/progress.vue /* normalize component */ var progress_component = normalizeComponent( src_progressvue_type_script_lang_js_, progressvue_type_template_id_229ee406_render, progressvue_type_template_id_229ee406_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var progress_api; } progress_component.options.__file = "packages/progress/src/progress.vue" /* harmony default export */ var progress = (progress_component.exports); // CONCATENATED MODULE: ./packages/progress/index.js /* istanbul ignore next */ progress.install = function (Vue) { Vue.component(progress.name, progress); }; /* harmony default export */ var packages_progress = (progress); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/spinner/src/spinner.vue?vue&type=template&id=697b8538& var spinnervue_type_template_id_697b8538_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("span", { staticClass: "el-spinner" }, [ _c( "svg", { staticClass: "el-spinner-inner", style: { width: _vm.radius / 2 + "px", height: _vm.radius / 2 + "px" }, attrs: { viewBox: "0 0 50 50" } }, [ _c("circle", { staticClass: "path", attrs: { cx: "25", cy: "25", r: "20", fill: "none", stroke: _vm.strokeColor, "stroke-width": _vm.strokeWidth } }) ] ) ]) } var spinnervue_type_template_id_697b8538_staticRenderFns = [] spinnervue_type_template_id_697b8538_render._withStripped = true // CONCATENATED MODULE: ./packages/spinner/src/spinner.vue?vue&type=template&id=697b8538& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/spinner/src/spinner.vue?vue&type=script&lang=js& // // // // // // // /* harmony default export */ var spinnervue_type_script_lang_js_ = ({ name: 'ElSpinner', props: { type: String, radius: { type: Number, default: 100 }, strokeWidth: { type: Number, default: 5 }, strokeColor: { type: String, default: '#efefef' } } }); // CONCATENATED MODULE: ./packages/spinner/src/spinner.vue?vue&type=script&lang=js& /* harmony default export */ var src_spinnervue_type_script_lang_js_ = (spinnervue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/spinner/src/spinner.vue /* normalize component */ var spinner_component = normalizeComponent( src_spinnervue_type_script_lang_js_, spinnervue_type_template_id_697b8538_render, spinnervue_type_template_id_697b8538_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var spinner_api; } spinner_component.options.__file = "packages/spinner/src/spinner.vue" /* harmony default export */ var spinner = (spinner_component.exports); // CONCATENATED MODULE: ./packages/spinner/index.js /* istanbul ignore next */ spinner.install = function (Vue) { Vue.component(spinner.name, spinner); }; /* harmony default export */ var packages_spinner = (spinner); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/message/src/main.vue?vue&type=template&id=455b9f60& var mainvue_type_template_id_455b9f60_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-message-fade" }, on: { "after-leave": _vm.handleAfterLeave } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], class: [ "el-message", _vm.type && !_vm.iconClass ? "el-message--" + _vm.type : "", _vm.center ? "is-center" : "", _vm.showClose ? "is-closable" : "", _vm.customClass ], style: _vm.positionStyle, attrs: { role: "alert" }, on: { mouseenter: _vm.clearTimer, mouseleave: _vm.startTimer } }, [ _vm.iconClass ? _c("i", { class: _vm.iconClass }) : _c("i", { class: _vm.typeClass }), _vm._t("default", [ !_vm.dangerouslyUseHTMLString ? _c("p", { staticClass: "el-message__content" }, [ _vm._v(_vm._s(_vm.message)) ]) : _c("p", { staticClass: "el-message__content", domProps: { innerHTML: _vm._s(_vm.message) } }) ]), _vm.showClose ? _c("i", { staticClass: "el-message__closeBtn el-icon-close", on: { click: _vm.close } }) : _vm._e() ], 2 ) ] ) } var mainvue_type_template_id_455b9f60_staticRenderFns = [] mainvue_type_template_id_455b9f60_render._withStripped = true // CONCATENATED MODULE: ./packages/message/src/main.vue?vue&type=template&id=455b9f60& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/message/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // var src_mainvue_type_script_lang_js_typeMap = { success: 'success', info: 'info', warning: 'warning', error: 'error' }; /* harmony default export */ var message_src_mainvue_type_script_lang_js_ = ({ data: function data() { return { visible: false, message: '', duration: 3000, type: 'info', iconClass: '', customClass: '', onClose: null, showClose: false, closed: false, verticalOffset: 20, timer: null, dangerouslyUseHTMLString: false, center: false }; }, computed: { typeClass: function typeClass() { return this.type && !this.iconClass ? 'el-message__icon el-icon-' + src_mainvue_type_script_lang_js_typeMap[this.type] : ''; }, positionStyle: function positionStyle() { return { 'top': this.verticalOffset + 'px' }; } }, watch: { closed: function closed(newVal) { if (newVal) { this.visible = false; } } }, methods: { handleAfterLeave: function handleAfterLeave() { this.$destroy(true); this.$el.parentNode.removeChild(this.$el); }, close: function close() { this.closed = true; if (typeof this.onClose === 'function') { this.onClose(this); } }, clearTimer: function clearTimer() { clearTimeout(this.timer); }, startTimer: function startTimer() { var _this = this; if (this.duration > 0) { this.timer = setTimeout(function () { if (!_this.closed) { _this.close(); } }, this.duration); } }, keydown: function keydown(e) { if (e.keyCode === 27) { // esc关闭消息 if (!this.closed) { this.close(); } } } }, mounted: function mounted() { this.startTimer(); document.addEventListener('keydown', this.keydown); }, beforeDestroy: function beforeDestroy() { document.removeEventListener('keydown', this.keydown); } }); // CONCATENATED MODULE: ./packages/message/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_message_src_mainvue_type_script_lang_js_ = (message_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/message/src/main.vue /* normalize component */ var message_src_main_component = normalizeComponent( packages_message_src_mainvue_type_script_lang_js_, mainvue_type_template_id_455b9f60_render, mainvue_type_template_id_455b9f60_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var message_src_main_api; } message_src_main_component.options.__file = "packages/message/src/main.vue" /* harmony default export */ var message_src_main = (message_src_main_component.exports); // CONCATENATED MODULE: ./packages/message/src/main.js var MessageConstructor = external_vue_default.a.extend(message_src_main); var message_src_main_instance = void 0; var main_instances = []; var main_seed = 1; var main_Message = function Message(options) { if (external_vue_default.a.prototype.$isServer) return; options = options || {}; if (typeof options === 'string') { options = { message: options }; } var userOnClose = options.onClose; var id = 'message_' + main_seed++; options.onClose = function () { Message.close(id, userOnClose); }; message_src_main_instance = new MessageConstructor({ data: options }); message_src_main_instance.id = id; if (Object(vdom_["isVNode"])(message_src_main_instance.message)) { message_src_main_instance.$slots.default = [message_src_main_instance.message]; message_src_main_instance.message = null; } message_src_main_instance.$mount(); document.body.appendChild(message_src_main_instance.$el); var verticalOffset = options.offset || 20; main_instances.forEach(function (item) { verticalOffset += item.$el.offsetHeight + 16; }); message_src_main_instance.verticalOffset = verticalOffset; message_src_main_instance.visible = true; message_src_main_instance.$el.style.zIndex = popup_["PopupManager"].nextZIndex(); main_instances.push(message_src_main_instance); return message_src_main_instance; }; ['success', 'warning', 'info', 'error'].forEach(function (type) { main_Message[type] = function (options) { if (typeof options === 'string') { options = { message: options }; } options.type = type; return main_Message(options); }; }); main_Message.close = function (id, userOnClose) { var len = main_instances.length; var index = -1; var removedHeight = void 0; for (var i = 0; i < len; i++) { if (id === main_instances[i].id) { removedHeight = main_instances[i].$el.offsetHeight; index = i; if (typeof userOnClose === 'function') { userOnClose(main_instances[i]); } main_instances.splice(i, 1); break; } } if (len <= 1 || index === -1 || index > main_instances.length - 1) return; for (var _i = index; _i < len - 1; _i++) { var dom = main_instances[_i].$el; dom.style['top'] = parseInt(dom.style['top'], 10) - removedHeight - 16 + 'px'; } }; main_Message.closeAll = function () { for (var i = main_instances.length - 1; i >= 0; i--) { main_instances[i].close(); } }; /* harmony default export */ var packages_message_src_main = (main_Message); // CONCATENATED MODULE: ./packages/message/index.js /* harmony default export */ var packages_message = (packages_message_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/badge/src/main.vue?vue&type=template&id=7ccb6598& var mainvue_type_template_id_7ccb6598_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-badge" }, [ _vm._t("default"), _c("transition", { attrs: { name: "el-zoom-in-center" } }, [ _c("sup", { directives: [ { name: "show", rawName: "v-show", value: !_vm.hidden && (_vm.content || _vm.content === 0 || _vm.isDot), expression: "!hidden && (content || content === 0 || isDot)" } ], staticClass: "el-badge__content", class: [ "el-badge__content--" + _vm.type, { "is-fixed": _vm.$slots.default, "is-dot": _vm.isDot } ], domProps: { textContent: _vm._s(_vm.content) } }) ]) ], 2 ) } var mainvue_type_template_id_7ccb6598_staticRenderFns = [] mainvue_type_template_id_7ccb6598_render._withStripped = true // CONCATENATED MODULE: ./packages/badge/src/main.vue?vue&type=template&id=7ccb6598& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/badge/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var badge_src_mainvue_type_script_lang_js_ = ({ name: 'ElBadge', props: { value: [String, Number], max: Number, isDot: Boolean, hidden: Boolean, type: { type: String, validator: function validator(val) { return ['primary', 'success', 'warning', 'info', 'danger'].indexOf(val) > -1; } } }, computed: { content: function content() { if (this.isDot) return; var value = this.value; var max = this.max; if (typeof value === 'number' && typeof max === 'number') { return max < value ? max + '+' : value; } return value; } } }); // CONCATENATED MODULE: ./packages/badge/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_badge_src_mainvue_type_script_lang_js_ = (badge_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/badge/src/main.vue /* normalize component */ var badge_src_main_component = normalizeComponent( packages_badge_src_mainvue_type_script_lang_js_, mainvue_type_template_id_7ccb6598_render, mainvue_type_template_id_7ccb6598_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var badge_src_main_api; } badge_src_main_component.options.__file = "packages/badge/src/main.vue" /* harmony default export */ var badge_src_main = (badge_src_main_component.exports); // CONCATENATED MODULE: ./packages/badge/index.js /* istanbul ignore next */ badge_src_main.install = function (Vue) { Vue.component(badge_src_main.name, badge_src_main); }; /* harmony default export */ var badge = (badge_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/card/src/main.vue?vue&type=template&id=59a4a40f& var mainvue_type_template_id_59a4a40f_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-card", class: _vm.shadow ? "is-" + _vm.shadow + "-shadow" : "is-always-shadow" }, [ _vm.$slots.header || _vm.header ? _c( "div", { staticClass: "el-card__header" }, [_vm._t("header", [_vm._v(_vm._s(_vm.header))])], 2 ) : _vm._e(), _c( "div", { staticClass: "el-card__body", style: _vm.bodyStyle }, [_vm._t("default")], 2 ) ] ) } var mainvue_type_template_id_59a4a40f_staticRenderFns = [] mainvue_type_template_id_59a4a40f_render._withStripped = true // CONCATENATED MODULE: ./packages/card/src/main.vue?vue&type=template&id=59a4a40f& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/card/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // /* harmony default export */ var card_src_mainvue_type_script_lang_js_ = ({ name: 'ElCard', props: { header: {}, bodyStyle: {}, shadow: { type: String } } }); // CONCATENATED MODULE: ./packages/card/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_card_src_mainvue_type_script_lang_js_ = (card_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/card/src/main.vue /* normalize component */ var card_src_main_component = normalizeComponent( packages_card_src_mainvue_type_script_lang_js_, mainvue_type_template_id_59a4a40f_render, mainvue_type_template_id_59a4a40f_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var card_src_main_api; } card_src_main_component.options.__file = "packages/card/src/main.vue" /* harmony default export */ var card_src_main = (card_src_main_component.exports); // CONCATENATED MODULE: ./packages/card/index.js /* istanbul ignore next */ card_src_main.install = function (Vue) { Vue.component(card_src_main.name, card_src_main); }; /* harmony default export */ var card = (card_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/rate/src/main.vue?vue&type=template&id=ada57782& var mainvue_type_template_id_ada57782_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-rate", attrs: { role: "slider", "aria-valuenow": _vm.currentValue, "aria-valuetext": _vm.text, "aria-valuemin": "0", "aria-valuemax": _vm.max, tabindex: "0" }, on: { keydown: _vm.handleKey } }, [ _vm._l(_vm.max, function(item, key) { return _c( "span", { key: key, staticClass: "el-rate__item", style: { cursor: _vm.rateDisabled ? "auto" : "pointer" }, on: { mousemove: function($event) { _vm.setCurrentValue(item, $event) }, mouseleave: _vm.resetCurrentValue, click: function($event) { _vm.selectValue(item) } } }, [ _c( "i", { staticClass: "el-rate__icon", class: [ _vm.classes[item - 1], { hover: _vm.hoverIndex === item } ], style: _vm.getIconStyle(item) }, [ _vm.showDecimalIcon(item) ? _c("i", { staticClass: "el-rate__decimal", class: _vm.decimalIconClass, style: _vm.decimalStyle }) : _vm._e() ] ) ] ) }), _vm.showText || _vm.showScore ? _c( "span", { staticClass: "el-rate__text", style: { color: _vm.textColor } }, [_vm._v(_vm._s(_vm.text))] ) : _vm._e() ], 2 ) } var mainvue_type_template_id_ada57782_staticRenderFns = [] mainvue_type_template_id_ada57782_render._withStripped = true // CONCATENATED MODULE: ./packages/rate/src/main.vue?vue&type=template&id=ada57782& // EXTERNAL MODULE: external "element-ui/lib/utils/types" var types_ = __webpack_require__(18); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/rate/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var rate_src_mainvue_type_script_lang_js_ = ({ name: 'ElRate', mixins: [migrating_default.a], inject: { elForm: { default: '' } }, data: function data() { return { pointerAtLeftHalf: true, currentValue: this.value, hoverIndex: -1 }; }, props: { value: { type: Number, default: 0 }, lowThreshold: { type: Number, default: 2 }, highThreshold: { type: Number, default: 4 }, max: { type: Number, default: 5 }, colors: { type: [Array, Object], default: function _default() { return ['#F7BA2A', '#F7BA2A', '#F7BA2A']; } }, voidColor: { type: String, default: '#C6D1DE' }, disabledVoidColor: { type: String, default: '#EFF2F7' }, iconClasses: { type: [Array, Object], default: function _default() { return ['el-icon-star-on', 'el-icon-star-on', 'el-icon-star-on']; } }, voidIconClass: { type: String, default: 'el-icon-star-off' }, disabledVoidIconClass: { type: String, default: 'el-icon-star-on' }, disabled: { type: Boolean, default: false }, allowHalf: { type: Boolean, default: false }, showText: { type: Boolean, default: false }, showScore: { type: Boolean, default: false }, textColor: { type: String, default: '#1f2d3d' }, texts: { type: Array, default: function _default() { return ['极差', '失望', '一般', '满意', '惊喜']; } }, scoreTemplate: { type: String, default: '{value}' } }, computed: { text: function text() { var result = ''; if (this.showScore) { result = this.scoreTemplate.replace(/\{\s*value\s*\}/, this.rateDisabled ? this.value : this.currentValue); } else if (this.showText) { result = this.texts[Math.ceil(this.currentValue) - 1]; } return result; }, decimalStyle: function decimalStyle() { var width = ''; if (this.rateDisabled) { width = this.valueDecimal + '%'; } else if (this.allowHalf) { width = '50%'; } return { color: this.activeColor, width: width }; }, valueDecimal: function valueDecimal() { return this.value * 100 - Math.floor(this.value) * 100; }, classMap: function classMap() { var _ref; return Array.isArray(this.iconClasses) ? (_ref = {}, _ref[this.lowThreshold] = this.iconClasses[0], _ref[this.highThreshold] = { value: this.iconClasses[1], excluded: true }, _ref[this.max] = this.iconClasses[2], _ref) : this.iconClasses; }, decimalIconClass: function decimalIconClass() { return this.getValueFromMap(this.value, this.classMap); }, voidClass: function voidClass() { return this.rateDisabled ? this.disabledVoidIconClass : this.voidIconClass; }, activeClass: function activeClass() { return this.getValueFromMap(this.currentValue, this.classMap); }, colorMap: function colorMap() { var _ref2; return Array.isArray(this.colors) ? (_ref2 = {}, _ref2[this.lowThreshold] = this.colors[0], _ref2[this.highThreshold] = { value: this.colors[1], excluded: true }, _ref2[this.max] = this.colors[2], _ref2) : this.colors; }, activeColor: function activeColor() { return this.getValueFromMap(this.currentValue, this.colorMap); }, classes: function classes() { var result = []; var i = 0; var threshold = this.currentValue; if (this.allowHalf && this.currentValue !== Math.floor(this.currentValue)) { threshold--; } for (; i < threshold; i++) { result.push(this.activeClass); } for (; i < this.max; i++) { result.push(this.voidClass); } return result; }, rateDisabled: function rateDisabled() { return this.disabled || (this.elForm || {}).disabled; } }, watch: { value: function value(val) { this.currentValue = val; this.pointerAtLeftHalf = this.value !== Math.floor(this.value); } }, methods: { getMigratingConfig: function getMigratingConfig() { return { props: { 'text-template': 'text-template is renamed to score-template.' } }; }, getValueFromMap: function getValueFromMap(value, map) { var matchedKeys = Object.keys(map).filter(function (key) { var val = map[key]; var excluded = Object(types_["isObject"])(val) ? val.excluded : false; return excluded ? value < key : value <= key; }).sort(function (a, b) { return a - b; }); var matchedValue = map[matchedKeys[0]]; return Object(types_["isObject"])(matchedValue) ? matchedValue.value : matchedValue || ''; }, showDecimalIcon: function showDecimalIcon(item) { var showWhenDisabled = this.rateDisabled && this.valueDecimal > 0 && item - 1 < this.value && item > this.value; /* istanbul ignore next */ var showWhenAllowHalf = this.allowHalf && this.pointerAtLeftHalf && item - 0.5 <= this.currentValue && item > this.currentValue; return showWhenDisabled || showWhenAllowHalf; }, getIconStyle: function getIconStyle(item) { var voidColor = this.rateDisabled ? this.disabledVoidColor : this.voidColor; return { color: item <= this.currentValue ? this.activeColor : voidColor }; }, selectValue: function selectValue(value) { if (this.rateDisabled) { return; } if (this.allowHalf && this.pointerAtLeftHalf) { this.$emit('input', this.currentValue); this.$emit('change', this.currentValue); } else { this.$emit('input', value); this.$emit('change', value); } }, handleKey: function handleKey(e) { if (this.rateDisabled) { return; } var currentValue = this.currentValue; var keyCode = e.keyCode; if (keyCode === 38 || keyCode === 39) { // left / down if (this.allowHalf) { currentValue += 0.5; } else { currentValue += 1; } e.stopPropagation(); e.preventDefault(); } else if (keyCode === 37 || keyCode === 40) { if (this.allowHalf) { currentValue -= 0.5; } else { currentValue -= 1; } e.stopPropagation(); e.preventDefault(); } currentValue = currentValue < 0 ? 0 : currentValue; currentValue = currentValue > this.max ? this.max : currentValue; this.$emit('input', currentValue); this.$emit('change', currentValue); }, setCurrentValue: function setCurrentValue(value, event) { if (this.rateDisabled) { return; } /* istanbul ignore if */ if (this.allowHalf) { var target = event.target; if (Object(dom_["hasClass"])(target, 'el-rate__item')) { target = target.querySelector('.el-rate__icon'); } if (Object(dom_["hasClass"])(target, 'el-rate__decimal')) { target = target.parentNode; } this.pointerAtLeftHalf = event.offsetX * 2 <= target.clientWidth; this.currentValue = this.pointerAtLeftHalf ? value - 0.5 : value; } else { this.currentValue = value; } this.hoverIndex = value; }, resetCurrentValue: function resetCurrentValue() { if (this.rateDisabled) { return; } if (this.allowHalf) { this.pointerAtLeftHalf = this.value !== Math.floor(this.value); } this.currentValue = this.value; this.hoverIndex = -1; } }, created: function created() { if (!this.value) { this.$emit('input', 0); } } }); // CONCATENATED MODULE: ./packages/rate/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_rate_src_mainvue_type_script_lang_js_ = (rate_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/rate/src/main.vue /* normalize component */ var rate_src_main_component = normalizeComponent( packages_rate_src_mainvue_type_script_lang_js_, mainvue_type_template_id_ada57782_render, mainvue_type_template_id_ada57782_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var rate_src_main_api; } rate_src_main_component.options.__file = "packages/rate/src/main.vue" /* harmony default export */ var rate_src_main = (rate_src_main_component.exports); // CONCATENATED MODULE: ./packages/rate/index.js /* istanbul ignore next */ rate_src_main.install = function (Vue) { Vue.component(rate_src_main.name, rate_src_main); }; /* harmony default export */ var rate = (rate_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/steps/src/steps.vue?vue&type=template&id=3c6b6dc0& var stepsvue_type_template_id_3c6b6dc0_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-steps", class: [ !_vm.simple && "el-steps--" + _vm.direction, _vm.simple && "el-steps--simple" ] }, [_vm._t("default")], 2 ) } var stepsvue_type_template_id_3c6b6dc0_staticRenderFns = [] stepsvue_type_template_id_3c6b6dc0_render._withStripped = true // CONCATENATED MODULE: ./packages/steps/src/steps.vue?vue&type=template&id=3c6b6dc0& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/steps/src/steps.vue?vue&type=script&lang=js& // // // // // // // // // // // /* harmony default export */ var stepsvue_type_script_lang_js_ = ({ name: 'ElSteps', mixins: [migrating_default.a], props: { space: [Number, String], active: Number, direction: { type: String, default: 'horizontal' }, alignCenter: Boolean, simple: Boolean, finishStatus: { type: String, default: 'finish' }, processStatus: { type: String, default: 'process' } }, data: function data() { return { steps: [], stepOffset: 0 }; }, methods: { getMigratingConfig: function getMigratingConfig() { return { props: { 'center': 'center is removed.' } }; } }, watch: { active: function active(newVal, oldVal) { this.$emit('change', newVal, oldVal); }, steps: function steps(_steps) { _steps.forEach(function (child, index) { child.index = index; }); } } }); // CONCATENATED MODULE: ./packages/steps/src/steps.vue?vue&type=script&lang=js& /* harmony default export */ var src_stepsvue_type_script_lang_js_ = (stepsvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/steps/src/steps.vue /* normalize component */ var steps_component = normalizeComponent( src_stepsvue_type_script_lang_js_, stepsvue_type_template_id_3c6b6dc0_render, stepsvue_type_template_id_3c6b6dc0_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var steps_api; } steps_component.options.__file = "packages/steps/src/steps.vue" /* harmony default export */ var steps = (steps_component.exports); // CONCATENATED MODULE: ./packages/steps/index.js /* istanbul ignore next */ steps.install = function (Vue) { Vue.component(steps.name, steps); }; /* harmony default export */ var packages_steps = (steps); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/steps/src/step.vue?vue&type=template&id=f414a87a& var stepvue_type_template_id_f414a87a_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-step", class: [ !_vm.isSimple && "is-" + _vm.$parent.direction, _vm.isSimple && "is-simple", _vm.isLast && !_vm.space && !_vm.isCenter && "is-flex", _vm.isCenter && !_vm.isVertical && !_vm.isSimple && "is-center" ], style: _vm.style }, [ _c( "div", { staticClass: "el-step__head", class: "is-" + _vm.currentStatus }, [ _c( "div", { staticClass: "el-step__line", style: _vm.isLast ? "" : { marginRight: _vm.$parent.stepOffset + "px" } }, [ _c("i", { staticClass: "el-step__line-inner", style: _vm.lineStyle }) ] ), _c( "div", { staticClass: "el-step__icon", class: "is-" + (_vm.icon ? "icon" : "text") }, [ _vm.currentStatus !== "success" && _vm.currentStatus !== "error" ? _vm._t("icon", [ _vm.icon ? _c("i", { staticClass: "el-step__icon-inner", class: [_vm.icon] }) : _vm._e(), !_vm.icon && !_vm.isSimple ? _c("div", { staticClass: "el-step__icon-inner" }, [ _vm._v(_vm._s(_vm.index + 1)) ]) : _vm._e() ]) : _c("i", { staticClass: "el-step__icon-inner is-status", class: [ "el-icon-" + (_vm.currentStatus === "success" ? "check" : "close") ] }) ], 2 ) ] ), _c("div", { staticClass: "el-step__main" }, [ _c( "div", { ref: "title", staticClass: "el-step__title", class: ["is-" + _vm.currentStatus] }, [_vm._t("title", [_vm._v(_vm._s(_vm.title))])], 2 ), _vm.isSimple ? _c("div", { staticClass: "el-step__arrow" }) : _c( "div", { staticClass: "el-step__description", class: ["is-" + _vm.currentStatus] }, [_vm._t("description", [_vm._v(_vm._s(_vm.description))])], 2 ) ]) ] ) } var stepvue_type_template_id_f414a87a_staticRenderFns = [] stepvue_type_template_id_f414a87a_render._withStripped = true // CONCATENATED MODULE: ./packages/steps/src/step.vue?vue&type=template&id=f414a87a& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/steps/src/step.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var stepvue_type_script_lang_js_ = ({ name: 'ElStep', props: { title: String, icon: String, description: String, status: String }, data: function data() { return { index: -1, lineStyle: {}, internalStatus: '' }; }, beforeCreate: function beforeCreate() { this.$parent.steps.push(this); }, beforeDestroy: function beforeDestroy() { var steps = this.$parent.steps; var index = steps.indexOf(this); if (index >= 0) { steps.splice(index, 1); } }, computed: { currentStatus: function currentStatus() { return this.status || this.internalStatus; }, prevStatus: function prevStatus() { var prevStep = this.$parent.steps[this.index - 1]; return prevStep ? prevStep.currentStatus : 'wait'; }, isCenter: function isCenter() { return this.$parent.alignCenter; }, isVertical: function isVertical() { return this.$parent.direction === 'vertical'; }, isSimple: function isSimple() { return this.$parent.simple; }, isLast: function isLast() { var parent = this.$parent; return parent.steps[parent.steps.length - 1] === this; }, stepsCount: function stepsCount() { return this.$parent.steps.length; }, space: function space() { var isSimple = this.isSimple, space = this.$parent.space; return isSimple ? '' : space; }, style: function style() { var style = {}; var parent = this.$parent; var len = parent.steps.length; var space = typeof this.space === 'number' ? this.space + 'px' : this.space ? this.space : 100 / (len - (this.isCenter ? 0 : 1)) + '%'; style.flexBasis = space; if (this.isVertical) return style; if (this.isLast) { style.maxWidth = 100 / this.stepsCount + '%'; } else { style.marginRight = -this.$parent.stepOffset + 'px'; } return style; } }, methods: { updateStatus: function updateStatus(val) { var prevChild = this.$parent.$children[this.index - 1]; if (val > this.index) { this.internalStatus = this.$parent.finishStatus; } else if (val === this.index && this.prevStatus !== 'error') { this.internalStatus = this.$parent.processStatus; } else { this.internalStatus = 'wait'; } if (prevChild) prevChild.calcProgress(this.internalStatus); }, calcProgress: function calcProgress(status) { var step = 100; var style = {}; style.transitionDelay = 150 * this.index + 'ms'; if (status === this.$parent.processStatus) { step = this.currentStatus !== 'error' ? 0 : 0; } else if (status === 'wait') { step = 0; style.transitionDelay = -150 * this.index + 'ms'; } style.borderWidth = step && !this.isSimple ? '1px' : 0; this.$parent.direction === 'vertical' ? style.height = step + '%' : style.width = step + '%'; this.lineStyle = style; } }, mounted: function mounted() { var _this = this; var unwatch = this.$watch('index', function (val) { _this.$watch('$parent.active', _this.updateStatus, { immediate: true }); _this.$watch('$parent.processStatus', function () { var activeIndex = _this.$parent.active; _this.updateStatus(activeIndex); }, { immediate: true }); unwatch(); }); } }); // CONCATENATED MODULE: ./packages/steps/src/step.vue?vue&type=script&lang=js& /* harmony default export */ var src_stepvue_type_script_lang_js_ = (stepvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/steps/src/step.vue /* normalize component */ var step_component = normalizeComponent( src_stepvue_type_script_lang_js_, stepvue_type_template_id_f414a87a_render, stepvue_type_template_id_f414a87a_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var step_api; } step_component.options.__file = "packages/steps/src/step.vue" /* harmony default export */ var step = (step_component.exports); // CONCATENATED MODULE: ./packages/step/index.js /* istanbul ignore next */ step.install = function (Vue) { Vue.component(step.name, step); }; /* harmony default export */ var packages_step = (step); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/main.vue?vue&type=template&id=5d5d1482& var mainvue_type_template_id_5d5d1482_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { class: _vm.carouselClasses, on: { mouseenter: function($event) { $event.stopPropagation() return _vm.handleMouseEnter($event) }, mouseleave: function($event) { $event.stopPropagation() return _vm.handleMouseLeave($event) } } }, [ _c( "div", { staticClass: "el-carousel__container", style: { height: _vm.height } }, [ _vm.arrowDisplay ? _c("transition", { attrs: { name: "carousel-arrow-left" } }, [ _c( "button", { directives: [ { name: "show", rawName: "v-show", value: (_vm.arrow === "always" || _vm.hover) && (_vm.loop || _vm.activeIndex > 0), expression: "(arrow === 'always' || hover) && (loop || activeIndex > 0)" } ], staticClass: "el-carousel__arrow el-carousel__arrow--left", attrs: { type: "button" }, on: { mouseenter: function($event) { _vm.handleButtonEnter("left") }, mouseleave: _vm.handleButtonLeave, click: function($event) { $event.stopPropagation() _vm.throttledArrowClick(_vm.activeIndex - 1) } } }, [_c("i", { staticClass: "el-icon-arrow-left" })] ) ]) : _vm._e(), _vm.arrowDisplay ? _c("transition", { attrs: { name: "carousel-arrow-right" } }, [ _c( "button", { directives: [ { name: "show", rawName: "v-show", value: (_vm.arrow === "always" || _vm.hover) && (_vm.loop || _vm.activeIndex < _vm.items.length - 1), expression: "(arrow === 'always' || hover) && (loop || activeIndex < items.length - 1)" } ], staticClass: "el-carousel__arrow el-carousel__arrow--right", attrs: { type: "button" }, on: { mouseenter: function($event) { _vm.handleButtonEnter("right") }, mouseleave: _vm.handleButtonLeave, click: function($event) { $event.stopPropagation() _vm.throttledArrowClick(_vm.activeIndex + 1) } } }, [_c("i", { staticClass: "el-icon-arrow-right" })] ) ]) : _vm._e(), _vm._t("default") ], 2 ), _vm.indicatorPosition !== "none" ? _c( "ul", { class: _vm.indicatorsClasses }, _vm._l(_vm.items, function(item, index) { return _c( "li", { key: index, class: [ "el-carousel__indicator", "el-carousel__indicator--" + _vm.direction, { "is-active": index === _vm.activeIndex } ], on: { mouseenter: function($event) { _vm.throttledIndicatorHover(index) }, click: function($event) { $event.stopPropagation() _vm.handleIndicatorClick(index) } } }, [ _c("button", { staticClass: "el-carousel__button" }, [ _vm.hasLabel ? _c("span", [_vm._v(_vm._s(item.label))]) : _vm._e() ]) ] ) }), 0 ) : _vm._e() ] ) } var mainvue_type_template_id_5d5d1482_staticRenderFns = [] mainvue_type_template_id_5d5d1482_render._withStripped = true // CONCATENATED MODULE: ./packages/carousel/src/main.vue?vue&type=template&id=5d5d1482& // EXTERNAL MODULE: external "throttle-debounce/throttle" var throttle_ = __webpack_require__(25); var throttle_default = /*#__PURE__*/__webpack_require__.n(throttle_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var carousel_src_mainvue_type_script_lang_js_ = ({ name: 'ElCarousel', props: { initialIndex: { type: Number, default: 0 }, height: String, trigger: { type: String, default: 'hover' }, autoplay: { type: Boolean, default: true }, interval: { type: Number, default: 3000 }, indicatorPosition: String, indicator: { type: Boolean, default: true }, arrow: { type: String, default: 'hover' }, type: String, loop: { type: Boolean, default: true }, direction: { type: String, default: 'horizontal', validator: function validator(val) { return ['horizontal', 'vertical'].indexOf(val) !== -1; } } }, data: function data() { return { items: [], activeIndex: -1, containerWidth: 0, timer: null, hover: false }; }, computed: { arrowDisplay: function arrowDisplay() { return this.arrow !== 'never' && this.direction !== 'vertical'; }, hasLabel: function hasLabel() { return this.items.some(function (item) { return item.label.toString().length > 0; }); }, carouselClasses: function carouselClasses() { var classes = ['el-carousel', 'el-carousel--' + this.direction]; if (this.type === 'card') { classes.push('el-carousel--card'); } return classes; }, indicatorsClasses: function indicatorsClasses() { var classes = ['el-carousel__indicators', 'el-carousel__indicators--' + this.direction]; if (this.hasLabel) { classes.push('el-carousel__indicators--labels'); } if (this.indicatorPosition === 'outside' || this.type === 'card') { classes.push('el-carousel__indicators--outside'); } return classes; } }, watch: { items: function items(val) { if (val.length > 0) this.setActiveItem(this.initialIndex); }, activeIndex: function activeIndex(val, oldVal) { this.resetItemPosition(oldVal); if (oldVal > -1) { this.$emit('change', val, oldVal); } }, autoplay: function autoplay(val) { val ? this.startTimer() : this.pauseTimer(); }, loop: function loop() { this.setActiveItem(this.activeIndex); } }, methods: { handleMouseEnter: function handleMouseEnter() { this.hover = true; this.pauseTimer(); }, handleMouseLeave: function handleMouseLeave() { this.hover = false; this.startTimer(); }, itemInStage: function itemInStage(item, index) { var length = this.items.length; if (index === length - 1 && item.inStage && this.items[0].active || item.inStage && this.items[index + 1] && this.items[index + 1].active) { return 'left'; } else if (index === 0 && item.inStage && this.items[length - 1].active || item.inStage && this.items[index - 1] && this.items[index - 1].active) { return 'right'; } return false; }, handleButtonEnter: function handleButtonEnter(arrow) { var _this = this; if (this.direction === 'vertical') return; this.items.forEach(function (item, index) { if (arrow === _this.itemInStage(item, index)) { item.hover = true; } }); }, handleButtonLeave: function handleButtonLeave() { if (this.direction === 'vertical') return; this.items.forEach(function (item) { item.hover = false; }); }, updateItems: function updateItems() { this.items = this.$children.filter(function (child) { return child.$options.name === 'ElCarouselItem'; }); }, resetItemPosition: function resetItemPosition(oldIndex) { var _this2 = this; this.items.forEach(function (item, index) { item.translateItem(index, _this2.activeIndex, oldIndex); }); }, playSlides: function playSlides() { if (this.activeIndex < this.items.length - 1) { this.activeIndex++; } else if (this.loop) { this.activeIndex = 0; } }, pauseTimer: function pauseTimer() { if (this.timer) { clearInterval(this.timer); this.timer = null; } }, startTimer: function startTimer() { if (this.interval <= 0 || !this.autoplay || this.timer) return; this.timer = setInterval(this.playSlides, this.interval); }, setActiveItem: function setActiveItem(index) { if (typeof index === 'string') { var filteredItems = this.items.filter(function (item) { return item.name === index; }); if (filteredItems.length > 0) { index = this.items.indexOf(filteredItems[0]); } } index = Number(index); if (isNaN(index) || index !== Math.floor(index)) { console.warn('[Element Warn][Carousel]index must be an integer.'); return; } var length = this.items.length; var oldIndex = this.activeIndex; if (index < 0) { this.activeIndex = this.loop ? length - 1 : 0; } else if (index >= length) { this.activeIndex = this.loop ? 0 : length - 1; } else { this.activeIndex = index; } if (oldIndex === this.activeIndex) { this.resetItemPosition(oldIndex); } }, prev: function prev() { this.setActiveItem(this.activeIndex - 1); }, next: function next() { this.setActiveItem(this.activeIndex + 1); }, handleIndicatorClick: function handleIndicatorClick(index) { this.activeIndex = index; }, handleIndicatorHover: function handleIndicatorHover(index) { if (this.trigger === 'hover' && index !== this.activeIndex) { this.activeIndex = index; } } }, created: function created() { var _this3 = this; this.throttledArrowClick = throttle_default()(300, true, function (index) { _this3.setActiveItem(index); }); this.throttledIndicatorHover = throttle_default()(300, function (index) { _this3.handleIndicatorHover(index); }); }, mounted: function mounted() { var _this4 = this; this.updateItems(); this.$nextTick(function () { Object(resize_event_["addResizeListener"])(_this4.$el, _this4.resetItemPosition); if (_this4.initialIndex < _this4.items.length && _this4.initialIndex >= 0) { _this4.activeIndex = _this4.initialIndex; } _this4.startTimer(); }); }, beforeDestroy: function beforeDestroy() { if (this.$el) Object(resize_event_["removeResizeListener"])(this.$el, this.resetItemPosition); this.pauseTimer(); } }); // CONCATENATED MODULE: ./packages/carousel/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_carousel_src_mainvue_type_script_lang_js_ = (carousel_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/carousel/src/main.vue /* normalize component */ var carousel_src_main_component = normalizeComponent( packages_carousel_src_mainvue_type_script_lang_js_, mainvue_type_template_id_5d5d1482_render, mainvue_type_template_id_5d5d1482_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var carousel_src_main_api; } carousel_src_main_component.options.__file = "packages/carousel/src/main.vue" /* harmony default export */ var carousel_src_main = (carousel_src_main_component.exports); // CONCATENATED MODULE: ./packages/carousel/index.js /* istanbul ignore next */ carousel_src_main.install = function (Vue) { Vue.component(carousel_src_main.name, carousel_src_main); }; /* harmony default export */ var carousel = (carousel_src_main); // CONCATENATED MODULE: ./packages/scrollbar/src/util.js var BAR_MAP = { vertical: { offset: 'offsetHeight', scroll: 'scrollTop', scrollSize: 'scrollHeight', size: 'height', key: 'vertical', axis: 'Y', client: 'clientY', direction: 'top' }, horizontal: { offset: 'offsetWidth', scroll: 'scrollLeft', scrollSize: 'scrollWidth', size: 'width', key: 'horizontal', axis: 'X', client: 'clientX', direction: 'left' } }; function renderThumbStyle(_ref) { var move = _ref.move, size = _ref.size, bar = _ref.bar; var style = {}; var translate = 'translate' + bar.axis + '(' + move + '%)'; style[bar.size] = size; style.transform = translate; style.msTransform = translate; style.webkitTransform = translate; return style; }; // CONCATENATED MODULE: ./packages/scrollbar/src/bar.js /* istanbul ignore next */ /* harmony default export */ var src_bar = ({ name: 'Bar', props: { vertical: Boolean, size: String, move: Number }, computed: { bar: function bar() { return BAR_MAP[this.vertical ? 'vertical' : 'horizontal']; }, wrap: function wrap() { return this.$parent.wrap; } }, render: function render(h) { var size = this.size, move = this.move, bar = this.bar; return h( 'div', { 'class': ['el-scrollbar__bar', 'is-' + bar.key], on: { 'mousedown': this.clickTrackHandler } }, [h('div', { ref: 'thumb', 'class': 'el-scrollbar__thumb', on: { 'mousedown': this.clickThumbHandler }, style: renderThumbStyle({ size: size, move: move, bar: bar }) })] ); }, methods: { clickThumbHandler: function clickThumbHandler(e) { // prevent click event of right button if (e.ctrlKey || e.button === 2) { return; } this.startDrag(e); this[this.bar.axis] = e.currentTarget[this.bar.offset] - (e[this.bar.client] - e.currentTarget.getBoundingClientRect()[this.bar.direction]); }, clickTrackHandler: function clickTrackHandler(e) { var offset = Math.abs(e.target.getBoundingClientRect()[this.bar.direction] - e[this.bar.client]); var thumbHalf = this.$refs.thumb[this.bar.offset] / 2; var thumbPositionPercentage = (offset - thumbHalf) * 100 / this.$el[this.bar.offset]; this.wrap[this.bar.scroll] = thumbPositionPercentage * this.wrap[this.bar.scrollSize] / 100; }, startDrag: function startDrag(e) { e.stopImmediatePropagation(); this.cursorDown = true; Object(dom_["on"])(document, 'mousemove', this.mouseMoveDocumentHandler); Object(dom_["on"])(document, 'mouseup', this.mouseUpDocumentHandler); document.onselectstart = function () { return false; }; }, mouseMoveDocumentHandler: function mouseMoveDocumentHandler(e) { if (this.cursorDown === false) return; var prevPage = this[this.bar.axis]; if (!prevPage) return; var offset = (this.$el.getBoundingClientRect()[this.bar.direction] - e[this.bar.client]) * -1; var thumbClickPosition = this.$refs.thumb[this.bar.offset] - prevPage; var thumbPositionPercentage = (offset - thumbClickPosition) * 100 / this.$el[this.bar.offset]; this.wrap[this.bar.scroll] = thumbPositionPercentage * this.wrap[this.bar.scrollSize] / 100; }, mouseUpDocumentHandler: function mouseUpDocumentHandler(e) { this.cursorDown = false; this[this.bar.axis] = 0; Object(dom_["off"])(document, 'mousemove', this.mouseMoveDocumentHandler); document.onselectstart = null; } }, destroyed: function destroyed() { Object(dom_["off"])(document, 'mouseup', this.mouseUpDocumentHandler); } }); // CONCATENATED MODULE: ./packages/scrollbar/src/main.js // reference https://github.com/noeldelgado/gemini-scrollbar/blob/master/index.js /* istanbul ignore next */ /* harmony default export */ var scrollbar_src_main = ({ name: 'ElScrollbar', components: { Bar: src_bar }, props: { native: Boolean, wrapStyle: {}, wrapClass: {}, viewClass: {}, viewStyle: {}, noresize: Boolean, // 如果 container 尺寸不会发生变化,最好设置它可以优化性能 tag: { type: String, default: 'div' } }, data: function data() { return { sizeWidth: '0', sizeHeight: '0', moveX: 0, moveY: 0 }; }, computed: { wrap: function wrap() { return this.$refs.wrap; } }, render: function render(h) { var gutter = scrollbar_width_default()(); var style = this.wrapStyle; if (gutter) { var gutterWith = '-' + gutter + 'px'; var gutterStyle = 'margin-bottom: ' + gutterWith + '; margin-right: ' + gutterWith + ';'; if (Array.isArray(this.wrapStyle)) { style = Object(util_["toObject"])(this.wrapStyle); style.marginRight = style.marginBottom = gutterWith; } else if (typeof this.wrapStyle === 'string') { style += gutterStyle; } else { style = gutterStyle; } } var view = h(this.tag, { class: ['el-scrollbar__view', this.viewClass], style: this.viewStyle, ref: 'resize' }, this.$slots.default); var wrap = h( 'div', { ref: 'wrap', style: style, on: { 'scroll': this.handleScroll }, 'class': [this.wrapClass, 'el-scrollbar__wrap', gutter ? '' : 'el-scrollbar__wrap--hidden-default'] }, [[view]] ); var nodes = void 0; if (!this.native) { nodes = [wrap, h(src_bar, { attrs: { move: this.moveX, size: this.sizeWidth } }), h(src_bar, { attrs: { vertical: true, move: this.moveY, size: this.sizeHeight } })]; } else { nodes = [h( 'div', { ref: 'wrap', 'class': [this.wrapClass, 'el-scrollbar__wrap'], style: style }, [[view]] )]; } return h('div', { class: 'el-scrollbar' }, nodes); }, methods: { handleScroll: function handleScroll() { var wrap = this.wrap; this.moveY = wrap.scrollTop * 100 / wrap.clientHeight; this.moveX = wrap.scrollLeft * 100 / wrap.clientWidth; }, update: function update() { var heightPercentage = void 0, widthPercentage = void 0; var wrap = this.wrap; if (!wrap) return; heightPercentage = wrap.clientHeight * 100 / wrap.scrollHeight; widthPercentage = wrap.clientWidth * 100 / wrap.scrollWidth; this.sizeHeight = heightPercentage < 100 ? heightPercentage + '%' : ''; this.sizeWidth = widthPercentage < 100 ? widthPercentage + '%' : ''; } }, mounted: function mounted() { if (this.native) return; this.$nextTick(this.update); !this.noresize && Object(resize_event_["addResizeListener"])(this.$refs.resize, this.update); }, beforeDestroy: function beforeDestroy() { if (this.native) return; !this.noresize && Object(resize_event_["removeResizeListener"])(this.$refs.resize, this.update); } }); // CONCATENATED MODULE: ./packages/scrollbar/index.js /* istanbul ignore next */ scrollbar_src_main.install = function (Vue) { Vue.component(scrollbar_src_main.name, scrollbar_src_main); }; /* harmony default export */ var scrollbar = (scrollbar_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/item.vue?vue&type=template&id=1801ae19& var itemvue_type_template_id_1801ae19_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.ready, expression: "ready" } ], staticClass: "el-carousel__item", class: { "is-active": _vm.active, "el-carousel__item--card": _vm.$parent.type === "card", "is-in-stage": _vm.inStage, "is-hover": _vm.hover, "is-animating": _vm.animating }, style: _vm.itemStyle, on: { click: _vm.handleItemClick } }, [ _vm.$parent.type === "card" ? _c("div", { directives: [ { name: "show", rawName: "v-show", value: !_vm.active, expression: "!active" } ], staticClass: "el-carousel__mask" }) : _vm._e(), _vm._t("default") ], 2 ) } var itemvue_type_template_id_1801ae19_staticRenderFns = [] itemvue_type_template_id_1801ae19_render._withStripped = true // CONCATENATED MODULE: ./packages/carousel/src/item.vue?vue&type=template&id=1801ae19& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/carousel/src/item.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // var CARD_SCALE = 0.83; /* harmony default export */ var itemvue_type_script_lang_js_ = ({ name: 'ElCarouselItem', props: { name: String, label: { type: [String, Number], default: '' } }, data: function data() { return { hover: false, translate: 0, scale: 1, active: false, ready: false, inStage: false, animating: false }; }, methods: { processIndex: function processIndex(index, activeIndex, length) { if (activeIndex === 0 && index === length - 1) { return -1; } else if (activeIndex === length - 1 && index === 0) { return length; } else if (index < activeIndex - 1 && activeIndex - index >= length / 2) { return length + 1; } else if (index > activeIndex + 1 && index - activeIndex >= length / 2) { return -2; } return index; }, calcCardTranslate: function calcCardTranslate(index, activeIndex) { var parentWidth = this.$parent.$el.offsetWidth; if (this.inStage) { return parentWidth * ((2 - CARD_SCALE) * (index - activeIndex) + 1) / 4; } else if (index < activeIndex) { return -(1 + CARD_SCALE) * parentWidth / 4; } else { return (3 + CARD_SCALE) * parentWidth / 4; } }, calcTranslate: function calcTranslate(index, activeIndex, isVertical) { var distance = this.$parent.$el[isVertical ? 'offsetHeight' : 'offsetWidth']; return distance * (index - activeIndex); }, translateItem: function translateItem(index, activeIndex, oldIndex) { var parentType = this.$parent.type; var parentDirection = this.parentDirection; var length = this.$parent.items.length; if (parentType !== 'card' && oldIndex !== undefined) { this.animating = index === activeIndex || index === oldIndex; } if (index !== activeIndex && length > 2 && this.$parent.loop) { index = this.processIndex(index, activeIndex, length); } if (parentType === 'card') { if (parentDirection === 'vertical') { console.warn('[Element Warn][Carousel]vertical direction is not supported in card mode'); } this.inStage = Math.round(Math.abs(index - activeIndex)) <= 1; this.active = index === activeIndex; this.translate = this.calcCardTranslate(index, activeIndex); this.scale = this.active ? 1 : CARD_SCALE; } else { this.active = index === activeIndex; var isVertical = parentDirection === 'vertical'; this.translate = this.calcTranslate(index, activeIndex, isVertical); } this.ready = true; }, handleItemClick: function handleItemClick() { var parent = this.$parent; if (parent && parent.type === 'card') { var index = parent.items.indexOf(this); parent.setActiveItem(index); } } }, computed: { parentDirection: function parentDirection() { return this.$parent.direction; }, itemStyle: function itemStyle() { var translateType = this.parentDirection === 'vertical' ? 'translateY' : 'translateX'; var value = translateType + '(' + this.translate + 'px) scale(' + this.scale + ')'; var style = { transform: value }; return Object(util_["autoprefixer"])(style); } }, created: function created() { this.$parent && this.$parent.updateItems(); }, destroyed: function destroyed() { this.$parent && this.$parent.updateItems(); } }); // CONCATENATED MODULE: ./packages/carousel/src/item.vue?vue&type=script&lang=js& /* harmony default export */ var src_itemvue_type_script_lang_js_ = (itemvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/carousel/src/item.vue /* normalize component */ var item_component = normalizeComponent( src_itemvue_type_script_lang_js_, itemvue_type_template_id_1801ae19_render, itemvue_type_template_id_1801ae19_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var item_api; } item_component.options.__file = "packages/carousel/src/item.vue" /* harmony default export */ var src_item = (item_component.exports); // CONCATENATED MODULE: ./packages/carousel-item/index.js /* istanbul ignore next */ src_item.install = function (Vue) { Vue.component(src_item.name, src_item); }; /* harmony default export */ var carousel_item = (src_item); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse.vue?vue&type=template&id=461d57f4& var collapsevue_type_template_id_461d57f4_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-collapse", attrs: { role: "tablist", "aria-multiselectable": "true" } }, [_vm._t("default")], 2 ) } var collapsevue_type_template_id_461d57f4_staticRenderFns = [] collapsevue_type_template_id_461d57f4_render._withStripped = true // CONCATENATED MODULE: ./packages/collapse/src/collapse.vue?vue&type=template&id=461d57f4& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse.vue?vue&type=script&lang=js& // // // // // /* harmony default export */ var collapsevue_type_script_lang_js_ = ({ name: 'ElCollapse', componentName: 'ElCollapse', props: { accordion: Boolean, value: { type: [Array, String, Number], default: function _default() { return []; } } }, data: function data() { return { activeNames: [].concat(this.value) }; }, provide: function provide() { return { collapse: this }; }, watch: { value: function value(_value) { this.activeNames = [].concat(_value); } }, methods: { setActiveNames: function setActiveNames(activeNames) { activeNames = [].concat(activeNames); var value = this.accordion ? activeNames[0] : activeNames; this.activeNames = activeNames; this.$emit('input', value); this.$emit('change', value); }, handleItemClick: function handleItemClick(item) { if (this.accordion) { this.setActiveNames((this.activeNames[0] || this.activeNames[0] === 0) && this.activeNames[0] === item.name ? '' : item.name); } else { var activeNames = this.activeNames.slice(0); var index = activeNames.indexOf(item.name); if (index > -1) { activeNames.splice(index, 1); } else { activeNames.push(item.name); } this.setActiveNames(activeNames); } } }, created: function created() { this.$on('item-click', this.handleItemClick); } }); // CONCATENATED MODULE: ./packages/collapse/src/collapse.vue?vue&type=script&lang=js& /* harmony default export */ var src_collapsevue_type_script_lang_js_ = (collapsevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/collapse/src/collapse.vue /* normalize component */ var collapse_component = normalizeComponent( src_collapsevue_type_script_lang_js_, collapsevue_type_template_id_461d57f4_render, collapsevue_type_template_id_461d57f4_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var collapse_api; } collapse_component.options.__file = "packages/collapse/src/collapse.vue" /* harmony default export */ var collapse = (collapse_component.exports); // CONCATENATED MODULE: ./packages/collapse/index.js /* istanbul ignore next */ collapse.install = function (Vue) { Vue.component(collapse.name, collapse); }; /* harmony default export */ var packages_collapse = (collapse); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse-item.vue?vue&type=template&id=2d05faac& var collapse_itemvue_type_template_id_2d05faac_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-collapse-item", class: { "is-active": _vm.isActive, "is-disabled": _vm.disabled } }, [ _c( "div", { attrs: { role: "tab", "aria-expanded": _vm.isActive, "aria-controls": "el-collapse-content-" + _vm.id, "aria-describedby": "el-collapse-content-" + _vm.id } }, [ _c( "div", { staticClass: "el-collapse-item__header", class: { focusing: _vm.focusing, "is-active": _vm.isActive }, attrs: { role: "button", id: "el-collapse-head-" + _vm.id, tabindex: _vm.disabled ? undefined : 0 }, on: { click: _vm.handleHeaderClick, keyup: function($event) { if ( !("button" in $event) && _vm._k($event.keyCode, "space", 32, $event.key, [ " ", "Spacebar" ]) && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter") ) { return null } $event.stopPropagation() return _vm.handleEnterClick($event) }, focus: _vm.handleFocus, blur: function($event) { _vm.focusing = false } } }, [ _vm._t("title", [_vm._v(_vm._s(_vm.title))]), _c("i", { staticClass: "el-collapse-item__arrow el-icon-arrow-right", class: { "is-active": _vm.isActive } }) ], 2 ) ] ), _c("el-collapse-transition", [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.isActive, expression: "isActive" } ], staticClass: "el-collapse-item__wrap", attrs: { role: "tabpanel", "aria-hidden": !_vm.isActive, "aria-labelledby": "el-collapse-head-" + _vm.id, id: "el-collapse-content-" + _vm.id } }, [ _c( "div", { staticClass: "el-collapse-item__content" }, [_vm._t("default")], 2 ) ] ) ]) ], 1 ) } var collapse_itemvue_type_template_id_2d05faac_staticRenderFns = [] collapse_itemvue_type_template_id_2d05faac_render._withStripped = true // CONCATENATED MODULE: ./packages/collapse/src/collapse-item.vue?vue&type=template&id=2d05faac& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/collapse/src/collapse-item.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var collapse_itemvue_type_script_lang_js_ = ({ name: 'ElCollapseItem', componentName: 'ElCollapseItem', mixins: [emitter_default.a], components: { ElCollapseTransition: collapse_transition_default.a }, data: function data() { return { contentWrapStyle: { height: 'auto', display: 'block' }, contentHeight: 0, focusing: false, isClick: false, id: Object(util_["generateId"])() }; }, inject: ['collapse'], props: { title: String, name: { type: [String, Number], default: function _default() { return this._uid; } }, disabled: Boolean }, computed: { isActive: function isActive() { return this.collapse.activeNames.indexOf(this.name) > -1; } }, methods: { handleFocus: function handleFocus() { var _this = this; setTimeout(function () { if (!_this.isClick) { _this.focusing = true; } else { _this.isClick = false; } }, 50); }, handleHeaderClick: function handleHeaderClick() { if (this.disabled) return; this.dispatch('ElCollapse', 'item-click', this); this.focusing = false; this.isClick = true; }, handleEnterClick: function handleEnterClick() { this.dispatch('ElCollapse', 'item-click', this); } } }); // CONCATENATED MODULE: ./packages/collapse/src/collapse-item.vue?vue&type=script&lang=js& /* harmony default export */ var src_collapse_itemvue_type_script_lang_js_ = (collapse_itemvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/collapse/src/collapse-item.vue /* normalize component */ var collapse_item_component = normalizeComponent( src_collapse_itemvue_type_script_lang_js_, collapse_itemvue_type_template_id_2d05faac_render, collapse_itemvue_type_template_id_2d05faac_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var collapse_item_api; } collapse_item_component.options.__file = "packages/collapse/src/collapse-item.vue" /* harmony default export */ var collapse_item = (collapse_item_component.exports); // CONCATENATED MODULE: ./packages/collapse-item/index.js /* istanbul ignore next */ collapse_item.install = function (Vue) { Vue.component(collapse_item.name, collapse_item); }; /* harmony default export */ var packages_collapse_item = (collapse_item); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader/src/cascader.vue?vue&type=template&id=032537a6& var cascadervue_type_template_id_032537a6_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: function() { return _vm.toggleDropDownVisible(false) }, expression: "() => toggleDropDownVisible(false)" } ], ref: "reference", class: [ "el-cascader", _vm.realSize && "el-cascader--" + _vm.realSize, { "is-disabled": _vm.isDisabled } ], on: { mouseenter: function($event) { _vm.inputHover = true }, mouseleave: function($event) { _vm.inputHover = false }, click: function() { return _vm.toggleDropDownVisible(_vm.readonly ? undefined : true) }, keydown: _vm.handleKeyDown } }, [ _c( "el-input", { ref: "input", class: { "is-focus": _vm.dropDownVisible }, attrs: { size: _vm.realSize, placeholder: _vm.placeholder, readonly: _vm.readonly, disabled: _vm.isDisabled, "validate-event": false }, on: { focus: _vm.handleFocus, blur: _vm.handleBlur, input: _vm.handleInput }, model: { value: _vm.multiple ? _vm.presentText : _vm.inputValue, callback: function($$v) { _vm.multiple ? _vm.presentText : (_vm.inputValue = $$v) }, expression: "multiple ? presentText : inputValue" } }, [ _c("template", { slot: "suffix" }, [ _vm.clearBtnVisible ? _c("i", { key: "clear", staticClass: "el-input__icon el-icon-circle-close", on: { click: function($event) { $event.stopPropagation() return _vm.handleClear($event) } } }) : _c("i", { key: "arrow-down", class: [ "el-input__icon", "el-icon-arrow-down", _vm.dropDownVisible && "is-reverse" ], on: { click: function($event) { $event.stopPropagation() _vm.toggleDropDownVisible() } } }) ]) ], 2 ), _vm.multiple ? _c( "div", { staticClass: "el-cascader__tags" }, [ _vm._l(_vm.presentTags, function(tag, index) { return _c( "el-tag", { key: tag.key, attrs: { type: "info", size: _vm.tagSize, hit: tag.hitState, closable: tag.closable, "disable-transitions": "" }, on: { close: function($event) { _vm.deleteTag(index) } } }, [_c("span", [_vm._v(_vm._s(tag.text))])] ) }), _vm.filterable && !_vm.isDisabled ? _c("input", { directives: [ { name: "model", rawName: "v-model.trim", value: _vm.inputValue, expression: "inputValue", modifiers: { trim: true } } ], staticClass: "el-cascader__search-input", attrs: { type: "text", placeholder: _vm.presentTags.length ? "" : _vm.placeholder }, domProps: { value: _vm.inputValue }, on: { input: [ function($event) { if ($event.target.composing) { return } _vm.inputValue = $event.target.value.trim() }, function(e) { return _vm.handleInput(_vm.inputValue, e) } ], click: function($event) { $event.stopPropagation() _vm.toggleDropDownVisible(true) }, keydown: function($event) { if ( !("button" in $event) && _vm._k( $event.keyCode, "delete", [8, 46], $event.key, ["Backspace", "Delete", "Del"] ) ) { return null } return _vm.handleDelete($event) }, blur: function($event) { _vm.$forceUpdate() } } }) : _vm._e() ], 2 ) : _vm._e(), _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.handleDropdownLeave } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.dropDownVisible, expression: "dropDownVisible" } ], ref: "popper", class: ["el-popper", "el-cascader__dropdown", _vm.popperClass] }, [ _c("el-cascader-panel", { directives: [ { name: "show", rawName: "v-show", value: !_vm.filtering, expression: "!filtering" } ], ref: "panel", attrs: { options: _vm.options, props: _vm.config, border: false, "render-label": _vm.$scopedSlots.default }, on: { "expand-change": _vm.handleExpandChange, close: function($event) { _vm.toggleDropDownVisible(false) } }, model: { value: _vm.checkedValue, callback: function($$v) { _vm.checkedValue = $$v }, expression: "checkedValue" } }), _vm.filterable ? _c( "el-scrollbar", { directives: [ { name: "show", rawName: "v-show", value: _vm.filtering, expression: "filtering" } ], ref: "suggestionPanel", staticClass: "el-cascader__suggestion-panel", attrs: { tag: "ul", "view-class": "el-cascader__suggestion-list" }, nativeOn: { keydown: function($event) { return _vm.handleSuggestionKeyDown($event) } } }, [ _vm.suggestions.length ? _vm._l(_vm.suggestions, function(item, index) { return _c( "li", { key: item.uid, class: [ "el-cascader__suggestion-item", item.checked && "is-checked" ], attrs: { tabindex: -1 }, on: { click: function($event) { _vm.handleSuggestionClick(index) } } }, [ _c("span", [_vm._v(_vm._s(item.text))]), item.checked ? _c("i", { staticClass: "el-icon-check" }) : _vm._e() ] ) }) : _vm._t("empty", [ _c( "li", { staticClass: "el-cascader__empty-text" }, [_vm._v(_vm._s(_vm.t("el.cascader.noMatch")))] ) ]) ], 2 ) : _vm._e() ], 1 ) ] ) ], 1 ) } var cascadervue_type_template_id_032537a6_staticRenderFns = [] cascadervue_type_template_id_032537a6_render._withStripped = true // CONCATENATED MODULE: ./packages/cascader/src/cascader.vue?vue&type=template&id=032537a6& // EXTERNAL MODULE: external "element-ui/lib/cascader-panel" var cascader_panel_ = __webpack_require__(42); var cascader_panel_default = /*#__PURE__*/__webpack_require__.n(cascader_panel_); // EXTERNAL MODULE: external "element-ui/lib/utils/aria-utils" var aria_utils_ = __webpack_require__(28); var aria_utils_default = /*#__PURE__*/__webpack_require__.n(aria_utils_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader/src/cascader.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var KeyCode = aria_utils_default.a.keys; var MigratingProps = { expandTrigger: { newProp: 'expandTrigger', type: String }, changeOnSelect: { newProp: 'checkStrictly', type: Boolean }, hoverThreshold: { newProp: 'hoverThreshold', type: Number } }; var PopperMixin = { props: { placement: { type: String, default: 'bottom-start' }, appendToBody: vue_popper_default.a.props.appendToBody, visibleArrow: { type: Boolean, default: true }, arrowOffset: vue_popper_default.a.props.arrowOffset, offset: vue_popper_default.a.props.offset, boundariesPadding: vue_popper_default.a.props.boundariesPadding, popperOptions: vue_popper_default.a.props.popperOptions }, methods: vue_popper_default.a.methods, data: vue_popper_default.a.data, beforeDestroy: vue_popper_default.a.beforeDestroy }; var InputSizeMap = { medium: 36, small: 32, mini: 28 }; /* harmony default export */ var cascadervue_type_script_lang_js_ = ({ name: 'ElCascader', directives: { Clickoutside: clickoutside_default.a }, mixins: [PopperMixin, emitter_default.a, locale_default.a, migrating_default.a], inject: { elForm: { default: '' }, elFormItem: { default: '' } }, components: { ElInput: input_default.a, ElTag: tag_default.a, ElScrollbar: scrollbar_default.a, ElCascaderPanel: cascader_panel_default.a }, props: { value: {}, options: Array, props: Object, size: String, placeholder: { type: String, default: function _default() { return Object(lib_locale_["t"])('el.cascader.placeholder'); } }, disabled: Boolean, clearable: Boolean, filterable: Boolean, filterMethod: Function, separator: { type: String, default: ' / ' }, showAllLevels: { type: Boolean, default: true }, collapseTags: Boolean, debounce: { type: Number, default: 300 }, beforeFilter: { type: Function, default: function _default() { return function () {}; } }, popperClass: String }, data: function data() { return { dropDownVisible: false, checkedValue: this.value || null, inputHover: false, inputValue: null, presentText: null, presentTags: [], checkedNodes: [], filtering: false, suggestions: [], inputInitialHeight: 0, pressDeleteCount: 0 }; }, computed: { realSize: function realSize() { var _elFormItemSize = (this.elFormItem || {}).elFormItemSize; return this.size || _elFormItemSize || (this.$ELEMENT || {}).size; }, tagSize: function tagSize() { return ['small', 'mini'].indexOf(this.realSize) > -1 ? 'mini' : 'small'; }, isDisabled: function isDisabled() { return this.disabled || (this.elForm || {}).disabled; }, config: function config() { var config = this.props || {}; var $attrs = this.$attrs; Object.keys(MigratingProps).forEach(function (oldProp) { var _MigratingProps$oldPr = MigratingProps[oldProp], newProp = _MigratingProps$oldPr.newProp, type = _MigratingProps$oldPr.type; var oldValue = $attrs[oldProp] || $attrs[Object(util_["kebabCase"])(oldProp)]; if (Object(shared_["isDef"])(oldProp) && !Object(shared_["isDef"])(config[newProp])) { if (type === Boolean && oldValue === '') { oldValue = true; } config[newProp] = oldValue; } }); return config; }, multiple: function multiple() { return this.config.multiple; }, leafOnly: function leafOnly() { return !this.config.checkStrictly; }, readonly: function readonly() { return !this.filterable || this.multiple; }, clearBtnVisible: function clearBtnVisible() { if (!this.clearable || this.isDisabled || this.filtering || !this.inputHover) { return false; } return this.multiple ? !!this.checkedNodes.filter(function (node) { return !node.isDisabled; }).length : !!this.presentText; }, panel: function panel() { return this.$refs.panel; } }, watch: { disabled: function disabled() { this.computePresentContent(); }, value: function value(val) { if (!Object(util_["isEqual"])(val, this.checkedValue)) { this.checkedValue = val; this.computePresentContent(); } }, checkedValue: function checkedValue(val) { var value = this.value, dropDownVisible = this.dropDownVisible; var _config = this.config, checkStrictly = _config.checkStrictly, multiple = _config.multiple; if (!Object(util_["isEqual"])(val, value) || Object(types_["isUndefined"])(value)) { this.computePresentContent(); // hide dropdown when single mode if (!multiple && !checkStrictly && dropDownVisible) { this.toggleDropDownVisible(false); } this.$emit('input', val); this.$emit('change', val); this.dispatch('ElFormItem', 'el.form.change', [val]); } }, options: { handler: function handler() { this.$nextTick(this.computePresentContent); }, deep: true }, presentText: function presentText(val) { this.inputValue = val; }, presentTags: function presentTags(val, oldVal) { if (this.multiple && (val.length || oldVal.length)) { this.$nextTick(this.updateStyle); } }, filtering: function filtering(val) { this.$nextTick(this.updatePopper); } }, mounted: function mounted() { var _this = this; var input = this.$refs.input; if (input && input.$el) { this.inputInitialHeight = input.$el.offsetHeight || InputSizeMap[this.realSize] || 40; } if (!Object(util_["isEmpty"])(this.value)) { this.computePresentContent(); } this.filterHandler = debounce_default()(this.debounce, function () { var inputValue = _this.inputValue; if (!inputValue) { _this.filtering = false; return; } var before = _this.beforeFilter(inputValue); if (before && before.then) { before.then(_this.getSuggestions); } else if (before !== false) { _this.getSuggestions(); } else { _this.filtering = false; } }); Object(resize_event_["addResizeListener"])(this.$el, this.updateStyle); }, beforeDestroy: function beforeDestroy() { Object(resize_event_["removeResizeListener"])(this.$el, this.updateStyle); }, methods: { getMigratingConfig: function getMigratingConfig() { return { props: { 'expand-trigger': 'expand-trigger is removed, use `props.expandTrigger` instead.', 'change-on-select': 'change-on-select is removed, use `props.checkStrictly` instead.', 'hover-threshold': 'hover-threshold is removed, use `props.hoverThreshold` instead' }, events: { 'active-item-change': 'active-item-change is renamed to expand-change' } }; }, toggleDropDownVisible: function toggleDropDownVisible(visible) { var _this2 = this; if (this.isDisabled) return; var dropDownVisible = this.dropDownVisible; var input = this.$refs.input; visible = Object(shared_["isDef"])(visible) ? visible : !dropDownVisible; if (visible !== dropDownVisible) { this.dropDownVisible = visible; if (visible) { this.$nextTick(function () { _this2.updatePopper(); _this2.panel.scrollIntoView(); }); } input.$refs.input.setAttribute('aria-expanded', visible); this.$emit('visible-change', visible); } }, handleDropdownLeave: function handleDropdownLeave() { this.filtering = false; this.inputValue = this.presentText; }, handleKeyDown: function handleKeyDown(event) { switch (event.keyCode) { case KeyCode.enter: this.toggleDropDownVisible(); break; case KeyCode.down: this.toggleDropDownVisible(true); this.focusFirstNode(); event.preventDefault(); break; case KeyCode.esc: case KeyCode.tab: this.toggleDropDownVisible(false); break; } }, handleFocus: function handleFocus(e) { this.$emit('focus', e); }, handleBlur: function handleBlur(e) { this.$emit('blur', e); }, handleInput: function handleInput(val, event) { !this.dropDownVisible && this.toggleDropDownVisible(true); if (event && event.isComposing) return; if (val) { this.filterHandler(); } else { this.filtering = false; } }, handleClear: function handleClear() { this.presentText = ''; this.panel.clearCheckedNodes(); }, handleExpandChange: function handleExpandChange(value) { this.$nextTick(this.updatePopper.bind(this)); this.$emit('expand-change', value); this.$emit('active-item-change', value); // Deprecated }, focusFirstNode: function focusFirstNode() { var _this3 = this; this.$nextTick(function () { var filtering = _this3.filtering; var _$refs = _this3.$refs, popper = _$refs.popper, suggestionPanel = _$refs.suggestionPanel; var firstNode = null; if (filtering && suggestionPanel) { firstNode = suggestionPanel.$el.querySelector('.el-cascader__suggestion-item'); } else { var firstMenu = popper.querySelector('.el-cascader-menu'); firstNode = firstMenu.querySelector('.el-cascader-node[tabindex="-1"]'); } if (firstNode) { firstNode.focus(); !filtering && firstNode.click(); } }); }, computePresentContent: function computePresentContent() { var _this4 = this; // nextTick is required, because checked nodes may not change right now this.$nextTick(function () { if (_this4.config.multiple) { _this4.computePresentTags(); _this4.presentText = _this4.presentTags.length ? ' ' : null; } else { _this4.computePresentText(); } }); }, computePresentText: function computePresentText() { var checkedValue = this.checkedValue, config = this.config; if (!Object(util_["isEmpty"])(checkedValue)) { var node = this.panel.getNodeByValue(checkedValue); if (node && (config.checkStrictly || node.isLeaf)) { this.presentText = node.getText(this.showAllLevels, this.separator); return; } } this.presentText = null; }, computePresentTags: function computePresentTags() { var isDisabled = this.isDisabled, leafOnly = this.leafOnly, showAllLevels = this.showAllLevels, separator = this.separator, collapseTags = this.collapseTags; var checkedNodes = this.getCheckedNodes(leafOnly); var tags = []; var genTag = function genTag(node) { return { node: node, key: node.uid, text: node.getText(showAllLevels, separator), hitState: false, closable: !isDisabled && !node.isDisabled }; }; if (checkedNodes.length) { var first = checkedNodes[0], rest = checkedNodes.slice(1); var restCount = rest.length; tags.push(genTag(first)); if (restCount) { if (collapseTags) { tags.push({ key: -1, text: '+ ' + restCount, closable: false }); } else { rest.forEach(function (node) { return tags.push(genTag(node)); }); } } } this.checkedNodes = checkedNodes; this.presentTags = tags; }, getSuggestions: function getSuggestions() { var _this5 = this; var filterMethod = this.filterMethod; if (!Object(types_["isFunction"])(filterMethod)) { filterMethod = function filterMethod(node, keyword) { return node.text.includes(keyword); }; } var suggestions = this.panel.getFlattedNodes(this.leafOnly).filter(function (node) { if (node.isDisabled) return false; node.text = node.getText(_this5.showAllLevels, _this5.separator) || ''; return filterMethod(node, _this5.inputValue); }); if (this.multiple) { this.presentTags.forEach(function (tag) { tag.hitState = false; }); } else { suggestions.forEach(function (node) { node.checked = Object(util_["isEqual"])(_this5.checkedValue, node.getValueByOption()); }); } this.filtering = true; this.suggestions = suggestions; this.$nextTick(this.updatePopper); }, handleSuggestionKeyDown: function handleSuggestionKeyDown(event) { var keyCode = event.keyCode, target = event.target; switch (keyCode) { case KeyCode.enter: target.click(); break; case KeyCode.up: var prev = target.previousElementSibling; prev && prev.focus(); break; case KeyCode.down: var next = target.nextElementSibling; next && next.focus(); break; case KeyCode.esc: case KeyCode.tab: this.toggleDropDownVisible(false); break; } }, handleDelete: function handleDelete() { var inputValue = this.inputValue, pressDeleteCount = this.pressDeleteCount, presentTags = this.presentTags; var lastIndex = presentTags.length - 1; var lastTag = presentTags[lastIndex]; this.pressDeleteCount = inputValue ? 0 : pressDeleteCount + 1; if (!lastTag) return; if (this.pressDeleteCount) { if (lastTag.hitState) { this.deleteTag(lastIndex); } else { lastTag.hitState = true; } } }, handleSuggestionClick: function handleSuggestionClick(index) { var multiple = this.multiple; var targetNode = this.suggestions[index]; if (multiple) { var checked = targetNode.checked; targetNode.doCheck(!checked); this.panel.calculateMultiCheckedValue(); } else { this.checkedValue = targetNode.getValueByOption(); this.toggleDropDownVisible(false); } }, deleteTag: function deleteTag(index) { var checkedValue = this.checkedValue; var val = checkedValue[index]; this.checkedValue = checkedValue.filter(function (n, i) { return i !== index; }); this.$emit('remove-tag', val); }, updateStyle: function updateStyle() { var $el = this.$el, inputInitialHeight = this.inputInitialHeight; if (this.$isServer || !$el) return; var suggestionPanel = this.$refs.suggestionPanel; var inputInner = $el.querySelector('.el-input__inner'); if (!inputInner) return; var tags = $el.querySelector('.el-cascader__tags'); var suggestionPanelEl = null; if (suggestionPanel && (suggestionPanelEl = suggestionPanel.$el)) { var suggestionList = suggestionPanelEl.querySelector('.el-cascader__suggestion-list'); suggestionList.style.minWidth = inputInner.offsetWidth + 'px'; } if (tags) { var offsetHeight = tags.offsetHeight; var height = Math.max(offsetHeight + 6, inputInitialHeight) + 'px'; inputInner.style.height = height; this.updatePopper(); } }, /** * public methods */ getCheckedNodes: function getCheckedNodes(leafOnly) { return this.panel.getCheckedNodes(leafOnly); } } }); // CONCATENATED MODULE: ./packages/cascader/src/cascader.vue?vue&type=script&lang=js& /* harmony default export */ var src_cascadervue_type_script_lang_js_ = (cascadervue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/cascader/src/cascader.vue /* normalize component */ var cascader_component = normalizeComponent( src_cascadervue_type_script_lang_js_, cascadervue_type_template_id_032537a6_render, cascadervue_type_template_id_032537a6_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var cascader_api; } cascader_component.options.__file = "packages/cascader/src/cascader.vue" /* harmony default export */ var cascader = (cascader_component.exports); // CONCATENATED MODULE: ./packages/cascader/index.js /* istanbul ignore next */ cascader.install = function (Vue) { Vue.component(cascader.name, cascader); }; /* harmony default export */ var packages_cascader = (cascader); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/main.vue?vue&type=template&id=55c8ade7& var mainvue_type_template_id_55c8ade7_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { directives: [ { name: "clickoutside", rawName: "v-clickoutside", value: _vm.hide, expression: "hide" } ], class: [ "el-color-picker", _vm.colorDisabled ? "is-disabled" : "", _vm.colorSize ? "el-color-picker--" + _vm.colorSize : "" ] }, [ _vm.colorDisabled ? _c("div", { staticClass: "el-color-picker__mask" }) : _vm._e(), _c( "div", { staticClass: "el-color-picker__trigger", on: { click: _vm.handleTrigger } }, [ _c( "span", { staticClass: "el-color-picker__color", class: { "is-alpha": _vm.showAlpha } }, [ _c("span", { staticClass: "el-color-picker__color-inner", style: { backgroundColor: _vm.displayedColor } }), !_vm.value && !_vm.showPanelColor ? _c("span", { staticClass: "el-color-picker__empty el-icon-close" }) : _vm._e() ] ), _c("span", { directives: [ { name: "show", rawName: "v-show", value: _vm.value || _vm.showPanelColor, expression: "value || showPanelColor" } ], staticClass: "el-color-picker__icon el-icon-arrow-down" }) ] ), _c("picker-dropdown", { ref: "dropdown", class: ["el-color-picker__panel", _vm.popperClass || ""], attrs: { color: _vm.color, "show-alpha": _vm.showAlpha, predefine: _vm.predefine }, on: { pick: _vm.confirmValue, clear: _vm.clearValue }, model: { value: _vm.showPicker, callback: function($$v) { _vm.showPicker = $$v }, expression: "showPicker" } }) ], 1 ) } var mainvue_type_template_id_55c8ade7_staticRenderFns = [] mainvue_type_template_id_55c8ade7_render._withStripped = true // CONCATENATED MODULE: ./packages/color-picker/src/main.vue?vue&type=template&id=55c8ade7& // CONCATENATED MODULE: ./packages/color-picker/src/color.js var color_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; }; function color_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var hsv2hsl = function hsv2hsl(hue, sat, val) { return [hue, sat * val / ((hue = (2 - sat) * val) < 1 ? hue : 2 - hue) || 0, hue / 2]; }; // Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1 // <http://stackoverflow.com/questions/7422072/javascript-how-to-detect-number-as-a-decimal-including-1-0> var isOnePointZero = function isOnePointZero(n) { return typeof n === 'string' && n.indexOf('.') !== -1 && parseFloat(n) === 1; }; var isPercentage = function isPercentage(n) { return typeof n === 'string' && n.indexOf('%') !== -1; }; // Take input from [0, n] and return it as [0, 1] var bound01 = function bound01(value, max) { if (isOnePointZero(value)) value = '100%'; var processPercent = isPercentage(value); value = Math.min(max, Math.max(0, parseFloat(value))); // Automatically convert percentage into number if (processPercent) { value = parseInt(value * max, 10) / 100; } // Handle floating point rounding errors if (Math.abs(value - max) < 0.000001) { return 1; } // Convert into [0, 1] range if it isn't already return value % max / parseFloat(max); }; var INT_HEX_MAP = { 10: 'A', 11: 'B', 12: 'C', 13: 'D', 14: 'E', 15: 'F' }; var toHex = function toHex(_ref) { var r = _ref.r, g = _ref.g, b = _ref.b; var hexOne = function hexOne(value) { value = Math.min(Math.round(value), 255); var high = Math.floor(value / 16); var low = value % 16; return '' + (INT_HEX_MAP[high] || high) + (INT_HEX_MAP[low] || low); }; if (isNaN(r) || isNaN(g) || isNaN(b)) return ''; return '#' + hexOne(r) + hexOne(g) + hexOne(b); }; var HEX_INT_MAP = { A: 10, B: 11, C: 12, D: 13, E: 14, F: 15 }; var parseHexChannel = function parseHexChannel(hex) { if (hex.length === 2) { return (HEX_INT_MAP[hex[0].toUpperCase()] || +hex[0]) * 16 + (HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1]); } return HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1]; }; var hsl2hsv = function hsl2hsv(hue, sat, light) { sat = sat / 100; light = light / 100; var smin = sat; var lmin = Math.max(light, 0.01); var sv = void 0; var v = void 0; light *= 2; sat *= light <= 1 ? light : 2 - light; smin *= lmin <= 1 ? lmin : 2 - lmin; v = (light + sat) / 2; sv = light === 0 ? 2 * smin / (lmin + smin) : 2 * sat / (light + sat); return { h: hue, s: sv * 100, v: v * 100 }; }; // `rgbToHsv` // Converts an RGB color value to HSV // *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1] // *Returns:* { h, s, v } in [0,1] var rgb2hsv = function rgb2hsv(r, g, b) { r = bound01(r, 255); g = bound01(g, 255); b = bound01(b, 255); var max = Math.max(r, g, b); var min = Math.min(r, g, b); var h = void 0, s = void 0; var v = max; var d = max - min; s = max === 0 ? 0 : d / max; if (max === min) { h = 0; // achromatic } else { switch (max) { case r: h = (g - b) / d + (g < b ? 6 : 0); break; case g: h = (b - r) / d + 2; break; case b: h = (r - g) / d + 4; break; } h /= 6; } return { h: h * 360, s: s * 100, v: v * 100 }; }; // `hsvToRgb` // Converts an HSV color value to RGB. // *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100] // *Returns:* { r, g, b } in the set [0, 255] var hsv2rgb = function hsv2rgb(h, s, v) { h = bound01(h, 360) * 6; s = bound01(s, 100); v = bound01(v, 100); var i = Math.floor(h); var f = h - i; var p = v * (1 - s); var q = v * (1 - f * s); var t = v * (1 - (1 - f) * s); var mod = i % 6; var r = [v, q, p, p, t, v][mod]; var g = [t, v, v, q, p, p][mod]; var b = [p, p, t, v, v, q][mod]; return { r: Math.round(r * 255), g: Math.round(g * 255), b: Math.round(b * 255) }; }; var Color = function () { function Color(options) { color_classCallCheck(this, Color); this._hue = 0; this._saturation = 100; this._value = 100; this._alpha = 100; this.enableAlpha = false; this.format = 'hex'; this.value = ''; options = options || {}; for (var option in options) { if (options.hasOwnProperty(option)) { this[option] = options[option]; } } this.doOnChange(); } Color.prototype.set = function set(prop, value) { if (arguments.length === 1 && (typeof prop === 'undefined' ? 'undefined' : color_typeof(prop)) === 'object') { for (var p in prop) { if (prop.hasOwnProperty(p)) { this.set(p, prop[p]); } } return; } this['_' + prop] = value; this.doOnChange(); }; Color.prototype.get = function get(prop) { return this['_' + prop]; }; Color.prototype.toRgb = function toRgb() { return hsv2rgb(this._hue, this._saturation, this._value); }; Color.prototype.fromString = function fromString(value) { var _this = this; if (!value) { this._hue = 0; this._saturation = 100; this._value = 100; this.doOnChange(); return; } var fromHSV = function fromHSV(h, s, v) { _this._hue = Math.max(0, Math.min(360, h)); _this._saturation = Math.max(0, Math.min(100, s)); _this._value = Math.max(0, Math.min(100, v)); _this.doOnChange(); }; if (value.indexOf('hsl') !== -1) { var parts = value.replace(/hsla|hsl|\(|\)/gm, '').split(/\s|,/g).filter(function (val) { return val !== ''; }).map(function (val, index) { return index > 2 ? parseFloat(val) : parseInt(val, 10); }); if (parts.length === 4) { this._alpha = Math.floor(parseFloat(parts[3]) * 100); } else if (parts.length === 3) { this._alpha = 100; } if (parts.length >= 3) { var _hsl2hsv = hsl2hsv(parts[0], parts[1], parts[2]), h = _hsl2hsv.h, s = _hsl2hsv.s, v = _hsl2hsv.v; fromHSV(h, s, v); } } else if (value.indexOf('hsv') !== -1) { var _parts = value.replace(/hsva|hsv|\(|\)/gm, '').split(/\s|,/g).filter(function (val) { return val !== ''; }).map(function (val, index) { return index > 2 ? parseFloat(val) : parseInt(val, 10); }); if (_parts.length === 4) { this._alpha = Math.floor(parseFloat(_parts[3]) * 100); } else if (_parts.length === 3) { this._alpha = 100; } if (_parts.length >= 3) { fromHSV(_parts[0], _parts[1], _parts[2]); } } else if (value.indexOf('rgb') !== -1) { var _parts2 = value.replace(/rgba|rgb|\(|\)/gm, '').split(/\s|,/g).filter(function (val) { return val !== ''; }).map(function (val, index) { return index > 2 ? parseFloat(val) : parseInt(val, 10); }); if (_parts2.length === 4) { this._alpha = Math.floor(parseFloat(_parts2[3]) * 100); } else if (_parts2.length === 3) { this._alpha = 100; } if (_parts2.length >= 3) { var _rgb2hsv = rgb2hsv(_parts2[0], _parts2[1], _parts2[2]), _h = _rgb2hsv.h, _s = _rgb2hsv.s, _v = _rgb2hsv.v; fromHSV(_h, _s, _v); } } else if (value.indexOf('#') !== -1) { var hex = value.replace('#', '').trim(); if (!/^(?:[0-9a-fA-F]{3}){1,2}$/.test(hex)) return; var r = void 0, g = void 0, b = void 0; if (hex.length === 3) { r = parseHexChannel(hex[0] + hex[0]); g = parseHexChannel(hex[1] + hex[1]); b = parseHexChannel(hex[2] + hex[2]); } else if (hex.length === 6 || hex.length === 8) { r = parseHexChannel(hex.substring(0, 2)); g = parseHexChannel(hex.substring(2, 4)); b = parseHexChannel(hex.substring(4, 6)); } if (hex.length === 8) { this._alpha = Math.floor(parseHexChannel(hex.substring(6)) / 255 * 100); } else if (hex.length === 3 || hex.length === 6) { this._alpha = 100; } var _rgb2hsv2 = rgb2hsv(r, g, b), _h2 = _rgb2hsv2.h, _s2 = _rgb2hsv2.s, _v2 = _rgb2hsv2.v; fromHSV(_h2, _s2, _v2); } }; Color.prototype.compare = function compare(color) { return Math.abs(color._hue - this._hue) < 2 && Math.abs(color._saturation - this._saturation) < 1 && Math.abs(color._value - this._value) < 1 && Math.abs(color._alpha - this._alpha) < 1; }; Color.prototype.doOnChange = function doOnChange() { var _hue = this._hue, _saturation = this._saturation, _value = this._value, _alpha = this._alpha, format = this.format; if (this.enableAlpha) { switch (format) { case 'hsl': var hsl = hsv2hsl(_hue, _saturation / 100, _value / 100); this.value = 'hsla(' + _hue + ', ' + Math.round(hsl[1] * 100) + '%, ' + Math.round(hsl[2] * 100) + '%, ' + _alpha / 100 + ')'; break; case 'hsv': this.value = 'hsva(' + _hue + ', ' + Math.round(_saturation) + '%, ' + Math.round(_value) + '%, ' + _alpha / 100 + ')'; break; default: var _hsv2rgb = hsv2rgb(_hue, _saturation, _value), r = _hsv2rgb.r, g = _hsv2rgb.g, b = _hsv2rgb.b; this.value = 'rgba(' + r + ', ' + g + ', ' + b + ', ' + _alpha / 100 + ')'; } } else { switch (format) { case 'hsl': var _hsl = hsv2hsl(_hue, _saturation / 100, _value / 100); this.value = 'hsl(' + _hue + ', ' + Math.round(_hsl[1] * 100) + '%, ' + Math.round(_hsl[2] * 100) + '%)'; break; case 'hsv': this.value = 'hsv(' + _hue + ', ' + Math.round(_saturation) + '%, ' + Math.round(_value) + '%)'; break; case 'rgb': var _hsv2rgb2 = hsv2rgb(_hue, _saturation, _value), _r = _hsv2rgb2.r, _g = _hsv2rgb2.g, _b = _hsv2rgb2.b; this.value = 'rgb(' + _r + ', ' + _g + ', ' + _b + ')'; break; default: this.value = toHex(hsv2rgb(_hue, _saturation, _value)); } } }; return Color; }(); /* harmony default export */ var src_color = (Color); ; // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/picker-dropdown.vue?vue&type=template&id=06601625& var picker_dropdownvue_type_template_id_06601625_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-zoom-in-top" }, on: { "after-leave": _vm.doDestroy } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.showPopper, expression: "showPopper" } ], staticClass: "el-color-dropdown" }, [ _c( "div", { staticClass: "el-color-dropdown__main-wrapper" }, [ _c("hue-slider", { ref: "hue", staticStyle: { float: "right" }, attrs: { color: _vm.color, vertical: "" } }), _c("sv-panel", { ref: "sl", attrs: { color: _vm.color } }) ], 1 ), _vm.showAlpha ? _c("alpha-slider", { ref: "alpha", attrs: { color: _vm.color } }) : _vm._e(), _vm.predefine ? _c("predefine", { attrs: { color: _vm.color, colors: _vm.predefine } }) : _vm._e(), _c( "div", { staticClass: "el-color-dropdown__btns" }, [ _c( "span", { staticClass: "el-color-dropdown__value" }, [ _c("el-input", { attrs: { "validate-event": false, size: "mini" }, on: { blur: _vm.handleConfirm }, nativeOn: { keyup: function($event) { if ( !("button" in $event) && _vm._k( $event.keyCode, "enter", 13, $event.key, "Enter" ) ) { return null } return _vm.handleConfirm($event) } }, model: { value: _vm.customInput, callback: function($$v) { _vm.customInput = $$v }, expression: "customInput" } }) ], 1 ), _c( "el-button", { staticClass: "el-color-dropdown__link-btn", attrs: { size: "mini", type: "text" }, on: { click: function($event) { _vm.$emit("clear") } } }, [ _vm._v( "\n " + _vm._s(_vm.t("el.colorpicker.clear")) + "\n " ) ] ), _c( "el-button", { staticClass: "el-color-dropdown__btn", attrs: { plain: "", size: "mini" }, on: { click: _vm.confirmValue } }, [ _vm._v( "\n " + _vm._s(_vm.t("el.colorpicker.confirm")) + "\n " ) ] ) ], 1 ) ], 1 ) ] ) } var picker_dropdownvue_type_template_id_06601625_staticRenderFns = [] picker_dropdownvue_type_template_id_06601625_render._withStripped = true // CONCATENATED MODULE: ./packages/color-picker/src/components/picker-dropdown.vue?vue&type=template&id=06601625& // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/sv-panel.vue?vue&type=template&id=d8583596& var sv_panelvue_type_template_id_d8583596_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-color-svpanel", style: { backgroundColor: _vm.background } }, [ _c("div", { staticClass: "el-color-svpanel__white" }), _c("div", { staticClass: "el-color-svpanel__black" }), _c( "div", { staticClass: "el-color-svpanel__cursor", style: { top: _vm.cursorTop + "px", left: _vm.cursorLeft + "px" } }, [_c("div")] ) ] ) } var sv_panelvue_type_template_id_d8583596_staticRenderFns = [] sv_panelvue_type_template_id_d8583596_render._withStripped = true // CONCATENATED MODULE: ./packages/color-picker/src/components/sv-panel.vue?vue&type=template&id=d8583596& // CONCATENATED MODULE: ./packages/color-picker/src/draggable.js var isDragging = false; /* harmony default export */ var draggable = (function (element, options) { if (external_vue_default.a.prototype.$isServer) return; var moveFn = function moveFn(event) { if (options.drag) { options.drag(event); } }; var upFn = function upFn(event) { document.removeEventListener('mousemove', moveFn); document.removeEventListener('mouseup', upFn); document.onselectstart = null; document.ondragstart = null; isDragging = false; if (options.end) { options.end(event); } }; element.addEventListener('mousedown', function (event) { if (isDragging) return; document.onselectstart = function () { return false; }; document.ondragstart = function () { return false; }; document.addEventListener('mousemove', moveFn); document.addEventListener('mouseup', upFn); isDragging = true; if (options.start) { options.start(event); } }); }); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/sv-panel.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // /* harmony default export */ var sv_panelvue_type_script_lang_js_ = ({ name: 'el-sl-panel', props: { color: { required: true } }, computed: { colorValue: function colorValue() { var hue = this.color.get('hue'); var value = this.color.get('value'); return { hue: hue, value: value }; } }, watch: { colorValue: function colorValue() { this.update(); } }, methods: { update: function update() { var saturation = this.color.get('saturation'); var value = this.color.get('value'); var el = this.$el; var width = el.clientWidth, height = el.clientHeight; this.cursorLeft = saturation * width / 100; this.cursorTop = (100 - value) * height / 100; this.background = 'hsl(' + this.color.get('hue') + ', 100%, 50%)'; }, handleDrag: function handleDrag(event) { var el = this.$el; var rect = el.getBoundingClientRect(); var left = event.clientX - rect.left; var top = event.clientY - rect.top; left = Math.max(0, left); left = Math.min(left, rect.width); top = Math.max(0, top); top = Math.min(top, rect.height); this.cursorLeft = left; this.cursorTop = top; this.color.set({ saturation: left / rect.width * 100, value: 100 - top / rect.height * 100 }); } }, mounted: function mounted() { var _this = this; draggable(this.$el, { drag: function drag(event) { _this.handleDrag(event); }, end: function end(event) { _this.handleDrag(event); } }); this.update(); }, data: function data() { return { cursorTop: 0, cursorLeft: 0, background: 'hsl(0, 100%, 50%)' }; } }); // CONCATENATED MODULE: ./packages/color-picker/src/components/sv-panel.vue?vue&type=script&lang=js& /* harmony default export */ var components_sv_panelvue_type_script_lang_js_ = (sv_panelvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/color-picker/src/components/sv-panel.vue /* normalize component */ var sv_panel_component = normalizeComponent( components_sv_panelvue_type_script_lang_js_, sv_panelvue_type_template_id_d8583596_render, sv_panelvue_type_template_id_d8583596_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var sv_panel_api; } sv_panel_component.options.__file = "packages/color-picker/src/components/sv-panel.vue" /* harmony default export */ var sv_panel = (sv_panel_component.exports); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/hue-slider.vue?vue&type=template&id=5cdc43b1& var hue_slidervue_type_template_id_5cdc43b1_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-color-hue-slider", class: { "is-vertical": _vm.vertical } }, [ _c("div", { ref: "bar", staticClass: "el-color-hue-slider__bar", on: { click: _vm.handleClick } }), _c("div", { ref: "thumb", staticClass: "el-color-hue-slider__thumb", style: { left: _vm.thumbLeft + "px", top: _vm.thumbTop + "px" } }) ] ) } var hue_slidervue_type_template_id_5cdc43b1_staticRenderFns = [] hue_slidervue_type_template_id_5cdc43b1_render._withStripped = true // CONCATENATED MODULE: ./packages/color-picker/src/components/hue-slider.vue?vue&type=template&id=5cdc43b1& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/hue-slider.vue?vue&type=script&lang=js& // // // // // // // // // // // // // /* harmony default export */ var hue_slidervue_type_script_lang_js_ = ({ name: 'el-color-hue-slider', props: { color: { required: true }, vertical: Boolean }, data: function data() { return { thumbLeft: 0, thumbTop: 0 }; }, computed: { hueValue: function hueValue() { var hue = this.color.get('hue'); return hue; } }, watch: { hueValue: function hueValue() { this.update(); } }, methods: { handleClick: function handleClick(event) { var thumb = this.$refs.thumb; var target = event.target; if (target !== thumb) { this.handleDrag(event); } }, handleDrag: function handleDrag(event) { var rect = this.$el.getBoundingClientRect(); var thumb = this.$refs.thumb; var hue = void 0; if (!this.vertical) { var left = event.clientX - rect.left; left = Math.min(left, rect.width - thumb.offsetWidth / 2); left = Math.max(thumb.offsetWidth / 2, left); hue = Math.round((left - thumb.offsetWidth / 2) / (rect.width - thumb.offsetWidth) * 360); } else { var top = event.clientY - rect.top; top = Math.min(top, rect.height - thumb.offsetHeight / 2); top = Math.max(thumb.offsetHeight / 2, top); hue = Math.round((top - thumb.offsetHeight / 2) / (rect.height - thumb.offsetHeight) * 360); } this.color.set('hue', hue); }, getThumbLeft: function getThumbLeft() { if (this.vertical) return 0; var el = this.$el; var hue = this.color.get('hue'); if (!el) return 0; var thumb = this.$refs.thumb; return Math.round(hue * (el.offsetWidth - thumb.offsetWidth / 2) / 360); }, getThumbTop: function getThumbTop() { if (!this.vertical) return 0; var el = this.$el; var hue = this.color.get('hue'); if (!el) return 0; var thumb = this.$refs.thumb; return Math.round(hue * (el.offsetHeight - thumb.offsetHeight / 2) / 360); }, update: function update() { this.thumbLeft = this.getThumbLeft(); this.thumbTop = this.getThumbTop(); } }, mounted: function mounted() { var _this = this; var _$refs = this.$refs, bar = _$refs.bar, thumb = _$refs.thumb; var dragConfig = { drag: function drag(event) { _this.handleDrag(event); }, end: function end(event) { _this.handleDrag(event); } }; draggable(bar, dragConfig); draggable(thumb, dragConfig); this.update(); } }); // CONCATENATED MODULE: ./packages/color-picker/src/components/hue-slider.vue?vue&type=script&lang=js& /* harmony default export */ var components_hue_slidervue_type_script_lang_js_ = (hue_slidervue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/color-picker/src/components/hue-slider.vue /* normalize component */ var hue_slider_component = normalizeComponent( components_hue_slidervue_type_script_lang_js_, hue_slidervue_type_template_id_5cdc43b1_render, hue_slidervue_type_template_id_5cdc43b1_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var hue_slider_api; } hue_slider_component.options.__file = "packages/color-picker/src/components/hue-slider.vue" /* harmony default export */ var hue_slider = (hue_slider_component.exports); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/alpha-slider.vue?vue&type=template&id=068c66cb& var alpha_slidervue_type_template_id_068c66cb_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-color-alpha-slider", class: { "is-vertical": _vm.vertical } }, [ _c("div", { ref: "bar", staticClass: "el-color-alpha-slider__bar", style: { background: _vm.background }, on: { click: _vm.handleClick } }), _c("div", { ref: "thumb", staticClass: "el-color-alpha-slider__thumb", style: { left: _vm.thumbLeft + "px", top: _vm.thumbTop + "px" } }) ] ) } var alpha_slidervue_type_template_id_068c66cb_staticRenderFns = [] alpha_slidervue_type_template_id_068c66cb_render._withStripped = true // CONCATENATED MODULE: ./packages/color-picker/src/components/alpha-slider.vue?vue&type=template&id=068c66cb& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/alpha-slider.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // /* harmony default export */ var alpha_slidervue_type_script_lang_js_ = ({ name: 'el-color-alpha-slider', props: { color: { required: true }, vertical: Boolean }, watch: { 'color._alpha': function color_alpha() { this.update(); }, 'color.value': function colorValue() { this.update(); } }, methods: { handleClick: function handleClick(event) { var thumb = this.$refs.thumb; var target = event.target; if (target !== thumb) { this.handleDrag(event); } }, handleDrag: function handleDrag(event) { var rect = this.$el.getBoundingClientRect(); var thumb = this.$refs.thumb; if (!this.vertical) { var left = event.clientX - rect.left; left = Math.max(thumb.offsetWidth / 2, left); left = Math.min(left, rect.width - thumb.offsetWidth / 2); this.color.set('alpha', Math.round((left - thumb.offsetWidth / 2) / (rect.width - thumb.offsetWidth) * 100)); } else { var top = event.clientY - rect.top; top = Math.max(thumb.offsetHeight / 2, top); top = Math.min(top, rect.height - thumb.offsetHeight / 2); this.color.set('alpha', Math.round((top - thumb.offsetHeight / 2) / (rect.height - thumb.offsetHeight) * 100)); } }, getThumbLeft: function getThumbLeft() { if (this.vertical) return 0; var el = this.$el; var alpha = this.color._alpha; if (!el) return 0; var thumb = this.$refs.thumb; return Math.round(alpha * (el.offsetWidth - thumb.offsetWidth / 2) / 100); }, getThumbTop: function getThumbTop() { if (!this.vertical) return 0; var el = this.$el; var alpha = this.color._alpha; if (!el) return 0; var thumb = this.$refs.thumb; return Math.round(alpha * (el.offsetHeight - thumb.offsetHeight / 2) / 100); }, getBackground: function getBackground() { if (this.color && this.color.value) { var _color$toRgb = this.color.toRgb(), r = _color$toRgb.r, g = _color$toRgb.g, b = _color$toRgb.b; return 'linear-gradient(to right, rgba(' + r + ', ' + g + ', ' + b + ', 0) 0%, rgba(' + r + ', ' + g + ', ' + b + ', 1) 100%)'; } return null; }, update: function update() { this.thumbLeft = this.getThumbLeft(); this.thumbTop = this.getThumbTop(); this.background = this.getBackground(); } }, data: function data() { return { thumbLeft: 0, thumbTop: 0, background: null }; }, mounted: function mounted() { var _this = this; var _$refs = this.$refs, bar = _$refs.bar, thumb = _$refs.thumb; var dragConfig = { drag: function drag(event) { _this.handleDrag(event); }, end: function end(event) { _this.handleDrag(event); } }; draggable(bar, dragConfig); draggable(thumb, dragConfig); this.update(); } }); // CONCATENATED MODULE: ./packages/color-picker/src/components/alpha-slider.vue?vue&type=script&lang=js& /* harmony default export */ var components_alpha_slidervue_type_script_lang_js_ = (alpha_slidervue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/color-picker/src/components/alpha-slider.vue /* normalize component */ var alpha_slider_component = normalizeComponent( components_alpha_slidervue_type_script_lang_js_, alpha_slidervue_type_template_id_068c66cb_render, alpha_slidervue_type_template_id_068c66cb_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var alpha_slider_api; } alpha_slider_component.options.__file = "packages/color-picker/src/components/alpha-slider.vue" /* harmony default export */ var alpha_slider = (alpha_slider_component.exports); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/predefine.vue?vue&type=template&id=06e03093& var predefinevue_type_template_id_06e03093_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("div", { staticClass: "el-color-predefine" }, [ _c( "div", { staticClass: "el-color-predefine__colors" }, _vm._l(_vm.rgbaColors, function(item, index) { return _c( "div", { key: _vm.colors[index], staticClass: "el-color-predefine__color-selector", class: { selected: item.selected, "is-alpha": item._alpha < 100 }, on: { click: function($event) { _vm.handleSelect(index) } } }, [_c("div", { style: { "background-color": item.value } })] ) }), 0 ) ]) } var predefinevue_type_template_id_06e03093_staticRenderFns = [] predefinevue_type_template_id_06e03093_render._withStripped = true // CONCATENATED MODULE: ./packages/color-picker/src/components/predefine.vue?vue&type=template&id=06e03093& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/predefine.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // /* harmony default export */ var predefinevue_type_script_lang_js_ = ({ props: { colors: { type: Array, required: true }, color: { required: true } }, data: function data() { return { rgbaColors: this.parseColors(this.colors, this.color) }; }, methods: { handleSelect: function handleSelect(index) { this.color.fromString(this.colors[index]); }, parseColors: function parseColors(colors, color) { return colors.map(function (value) { var c = new src_color(); c.enableAlpha = true; c.format = 'rgba'; c.fromString(value); c.selected = c.value === color.value; return c; }); } }, watch: { '$parent.currentColor': function $parentCurrentColor(val) { var color = new src_color(); color.fromString(val); this.rgbaColors.forEach(function (item) { item.selected = color.compare(item); }); }, colors: function colors(newVal) { this.rgbaColors = this.parseColors(newVal, this.color); }, color: function color(newVal) { this.rgbaColors = this.parseColors(this.colors, newVal); } } }); // CONCATENATED MODULE: ./packages/color-picker/src/components/predefine.vue?vue&type=script&lang=js& /* harmony default export */ var components_predefinevue_type_script_lang_js_ = (predefinevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/color-picker/src/components/predefine.vue /* normalize component */ var predefine_component = normalizeComponent( components_predefinevue_type_script_lang_js_, predefinevue_type_template_id_06e03093_render, predefinevue_type_template_id_06e03093_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var predefine_api; } predefine_component.options.__file = "packages/color-picker/src/components/predefine.vue" /* harmony default export */ var predefine = (predefine_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/components/picker-dropdown.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var picker_dropdownvue_type_script_lang_js_ = ({ name: 'el-color-picker-dropdown', mixins: [vue_popper_default.a, locale_default.a], components: { SvPanel: sv_panel, HueSlider: hue_slider, AlphaSlider: alpha_slider, ElInput: input_default.a, ElButton: button_default.a, Predefine: predefine }, props: { color: { required: true }, showAlpha: Boolean, predefine: Array }, data: function data() { return { customInput: '' }; }, computed: { currentColor: function currentColor() { var parent = this.$parent; return !parent.value && !parent.showPanelColor ? '' : parent.color.value; } }, methods: { confirmValue: function confirmValue() { this.$emit('pick'); }, handleConfirm: function handleConfirm() { this.color.fromString(this.customInput); } }, mounted: function mounted() { this.$parent.popperElm = this.popperElm = this.$el; this.referenceElm = this.$parent.$el; }, watch: { showPopper: function showPopper(val) { var _this = this; if (val === true) { this.$nextTick(function () { var _$refs = _this.$refs, sl = _$refs.sl, hue = _$refs.hue, alpha = _$refs.alpha; sl && sl.update(); hue && hue.update(); alpha && alpha.update(); }); } }, currentColor: { immediate: true, handler: function handler(val) { this.customInput = val; } } } }); // CONCATENATED MODULE: ./packages/color-picker/src/components/picker-dropdown.vue?vue&type=script&lang=js& /* harmony default export */ var components_picker_dropdownvue_type_script_lang_js_ = (picker_dropdownvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/color-picker/src/components/picker-dropdown.vue /* normalize component */ var picker_dropdown_component = normalizeComponent( components_picker_dropdownvue_type_script_lang_js_, picker_dropdownvue_type_template_id_06601625_render, picker_dropdownvue_type_template_id_06601625_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var picker_dropdown_api; } picker_dropdown_component.options.__file = "packages/color-picker/src/components/picker-dropdown.vue" /* harmony default export */ var picker_dropdown = (picker_dropdown_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/color-picker/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var color_picker_src_mainvue_type_script_lang_js_ = ({ name: 'ElColorPicker', mixins: [emitter_default.a], props: { value: String, showAlpha: Boolean, colorFormat: String, disabled: Boolean, size: String, popperClass: String, predefine: Array }, inject: { elForm: { default: '' }, elFormItem: { default: '' } }, directives: { Clickoutside: clickoutside_default.a }, computed: { displayedColor: function displayedColor() { if (!this.value && !this.showPanelColor) { return 'transparent'; } return this.displayedRgb(this.color, this.showAlpha); }, _elFormItemSize: function _elFormItemSize() { return (this.elFormItem || {}).elFormItemSize; }, colorSize: function colorSize() { return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size; }, colorDisabled: function colorDisabled() { return this.disabled || (this.elForm || {}).disabled; } }, watch: { value: function value(val) { if (!val) { this.showPanelColor = false; } else if (val && val !== this.color.value) { this.color.fromString(val); } }, color: { deep: true, handler: function handler() { this.showPanelColor = true; } }, displayedColor: function displayedColor(val) { if (!this.showPicker) return; var currentValueColor = new src_color({ enableAlpha: this.showAlpha, format: this.colorFormat }); currentValueColor.fromString(this.value); var currentValueColorRgb = this.displayedRgb(currentValueColor, this.showAlpha); if (val !== currentValueColorRgb) { this.$emit('active-change', val); } } }, methods: { handleTrigger: function handleTrigger() { if (this.colorDisabled) return; this.showPicker = !this.showPicker; }, confirmValue: function confirmValue() { var value = this.color.value; this.$emit('input', value); this.$emit('change', value); this.dispatch('ElFormItem', 'el.form.change', value); this.showPicker = false; }, clearValue: function clearValue() { this.$emit('input', null); this.$emit('change', null); if (this.value !== null) { this.dispatch('ElFormItem', 'el.form.change', null); } this.showPanelColor = false; this.showPicker = false; this.resetColor(); }, hide: function hide() { this.showPicker = false; this.resetColor(); }, resetColor: function resetColor() { var _this = this; this.$nextTick(function (_) { if (_this.value) { _this.color.fromString(_this.value); } else { _this.showPanelColor = false; } }); }, displayedRgb: function displayedRgb(color, showAlpha) { if (!(color instanceof src_color)) { throw Error('color should be instance of Color Class'); } var _color$toRgb = color.toRgb(), r = _color$toRgb.r, g = _color$toRgb.g, b = _color$toRgb.b; return showAlpha ? 'rgba(' + r + ', ' + g + ', ' + b + ', ' + color.get('alpha') / 100 + ')' : 'rgb(' + r + ', ' + g + ', ' + b + ')'; } }, mounted: function mounted() { var value = this.value; if (value) { this.color.fromString(value); } this.popperElm = this.$refs.dropdown.$el; }, data: function data() { var color = new src_color({ enableAlpha: this.showAlpha, format: this.colorFormat }); return { color: color, showPicker: false, showPanelColor: false }; }, components: { PickerDropdown: picker_dropdown } }); // CONCATENATED MODULE: ./packages/color-picker/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_color_picker_src_mainvue_type_script_lang_js_ = (color_picker_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/color-picker/src/main.vue /* normalize component */ var color_picker_src_main_component = normalizeComponent( packages_color_picker_src_mainvue_type_script_lang_js_, mainvue_type_template_id_55c8ade7_render, mainvue_type_template_id_55c8ade7_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var color_picker_src_main_api; } color_picker_src_main_component.options.__file = "packages/color-picker/src/main.vue" /* harmony default export */ var color_picker_src_main = (color_picker_src_main_component.exports); // CONCATENATED MODULE: ./packages/color-picker/index.js /* istanbul ignore next */ color_picker_src_main.install = function (Vue) { Vue.component(color_picker_src_main.name, color_picker_src_main); }; /* harmony default export */ var color_picker = (color_picker_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/transfer/src/main.vue?vue&type=template&id=5c654dd8& var mainvue_type_template_id_5c654dd8_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-transfer" }, [ _c( "transfer-panel", _vm._b( { ref: "leftPanel", attrs: { data: _vm.sourceData, title: _vm.titles[0] || _vm.t("el.transfer.titles.0"), "default-checked": _vm.leftDefaultChecked, placeholder: _vm.filterPlaceholder || _vm.t("el.transfer.filterPlaceholder") }, on: { "checked-change": _vm.onSourceCheckedChange } }, "transfer-panel", _vm.$props, false ), [_vm._t("left-footer")], 2 ), _c( "div", { staticClass: "el-transfer__buttons" }, [ _c( "el-button", { class: [ "el-transfer__button", _vm.hasButtonTexts ? "is-with-texts" : "" ], attrs: { type: "primary", disabled: _vm.rightChecked.length === 0 }, nativeOn: { click: function($event) { return _vm.addToLeft($event) } } }, [ _c("i", { staticClass: "el-icon-arrow-left" }), _vm.buttonTexts[0] !== undefined ? _c("span", [_vm._v(_vm._s(_vm.buttonTexts[0]))]) : _vm._e() ] ), _c( "el-button", { class: [ "el-transfer__button", _vm.hasButtonTexts ? "is-with-texts" : "" ], attrs: { type: "primary", disabled: _vm.leftChecked.length === 0 }, nativeOn: { click: function($event) { return _vm.addToRight($event) } } }, [ _vm.buttonTexts[1] !== undefined ? _c("span", [_vm._v(_vm._s(_vm.buttonTexts[1]))]) : _vm._e(), _c("i", { staticClass: "el-icon-arrow-right" }) ] ) ], 1 ), _c( "transfer-panel", _vm._b( { ref: "rightPanel", attrs: { data: _vm.targetData, title: _vm.titles[1] || _vm.t("el.transfer.titles.1"), "default-checked": _vm.rightDefaultChecked, placeholder: _vm.filterPlaceholder || _vm.t("el.transfer.filterPlaceholder") }, on: { "checked-change": _vm.onTargetCheckedChange } }, "transfer-panel", _vm.$props, false ), [_vm._t("right-footer")], 2 ) ], 1 ) } var mainvue_type_template_id_5c654dd8_staticRenderFns = [] mainvue_type_template_id_5c654dd8_render._withStripped = true // CONCATENATED MODULE: ./packages/transfer/src/main.vue?vue&type=template&id=5c654dd8& // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/transfer/src/transfer-panel.vue?vue&type=template&id=2ddab8bd& var transfer_panelvue_type_template_id_2ddab8bd_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("div", { staticClass: "el-transfer-panel" }, [ _c( "p", { staticClass: "el-transfer-panel__header" }, [ _c( "el-checkbox", { attrs: { indeterminate: _vm.isIndeterminate }, on: { change: _vm.handleAllCheckedChange }, model: { value: _vm.allChecked, callback: function($$v) { _vm.allChecked = $$v }, expression: "allChecked" } }, [ _vm._v("\n " + _vm._s(_vm.title) + "\n "), _c("span", [_vm._v(_vm._s(_vm.checkedSummary))]) ] ) ], 1 ), _c( "div", { class: [ "el-transfer-panel__body", _vm.hasFooter ? "is-with-footer" : "" ] }, [ _vm.filterable ? _c( "el-input", { staticClass: "el-transfer-panel__filter", attrs: { size: "small", placeholder: _vm.placeholder }, nativeOn: { mouseenter: function($event) { _vm.inputHover = true }, mouseleave: function($event) { _vm.inputHover = false } }, model: { value: _vm.query, callback: function($$v) { _vm.query = $$v }, expression: "query" } }, [ _c("i", { class: ["el-input__icon", "el-icon-" + _vm.inputIcon], attrs: { slot: "prefix" }, on: { click: _vm.clearQuery }, slot: "prefix" }) ] ) : _vm._e(), _c( "el-checkbox-group", { directives: [ { name: "show", rawName: "v-show", value: !_vm.hasNoMatch && _vm.data.length > 0, expression: "!hasNoMatch && data.length > 0" } ], staticClass: "el-transfer-panel__list", class: { "is-filterable": _vm.filterable }, model: { value: _vm.checked, callback: function($$v) { _vm.checked = $$v }, expression: "checked" } }, _vm._l(_vm.filteredData, function(item) { return _c( "el-checkbox", { key: item[_vm.keyProp], staticClass: "el-transfer-panel__item", attrs: { label: item[_vm.keyProp], disabled: item[_vm.disabledProp] } }, [_c("option-content", { attrs: { option: item } })], 1 ) }), 1 ), _c( "p", { directives: [ { name: "show", rawName: "v-show", value: _vm.hasNoMatch, expression: "hasNoMatch" } ], staticClass: "el-transfer-panel__empty" }, [_vm._v(_vm._s(_vm.t("el.transfer.noMatch")))] ), _c( "p", { directives: [ { name: "show", rawName: "v-show", value: _vm.data.length === 0 && !_vm.hasNoMatch, expression: "data.length === 0 && !hasNoMatch" } ], staticClass: "el-transfer-panel__empty" }, [_vm._v(_vm._s(_vm.t("el.transfer.noData")))] ) ], 1 ), _vm.hasFooter ? _c( "p", { staticClass: "el-transfer-panel__footer" }, [_vm._t("default")], 2 ) : _vm._e() ]) } var transfer_panelvue_type_template_id_2ddab8bd_staticRenderFns = [] transfer_panelvue_type_template_id_2ddab8bd_render._withStripped = true // CONCATENATED MODULE: ./packages/transfer/src/transfer-panel.vue?vue&type=template&id=2ddab8bd& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/transfer/src/transfer-panel.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var transfer_panelvue_type_script_lang_js_ = ({ mixins: [locale_default.a], name: 'ElTransferPanel', componentName: 'ElTransferPanel', components: { ElCheckboxGroup: checkbox_group_default.a, ElCheckbox: checkbox_default.a, ElInput: input_default.a, OptionContent: { props: { option: Object }, render: function render(h) { var getParent = function getParent(vm) { if (vm.$options.componentName === 'ElTransferPanel') { return vm; } else if (vm.$parent) { return getParent(vm.$parent); } else { return vm; } }; var panel = getParent(this); var transfer = panel.$parent || panel; return panel.renderContent ? panel.renderContent(h, this.option) : transfer.$scopedSlots.default ? transfer.$scopedSlots.default({ option: this.option }) : h('span', [this.option[panel.labelProp] || this.option[panel.keyProp]]); } } }, props: { data: { type: Array, default: function _default() { return []; } }, renderContent: Function, placeholder: String, title: String, filterable: Boolean, format: Object, filterMethod: Function, defaultChecked: Array, props: Object }, data: function data() { return { checked: [], allChecked: false, query: '', inputHover: false, checkChangeByUser: true }; }, watch: { checked: function checked(val, oldVal) { this.updateAllChecked(); if (this.checkChangeByUser) { var movedKeys = val.concat(oldVal).filter(function (v) { return val.indexOf(v) === -1 || oldVal.indexOf(v) === -1; }); this.$emit('checked-change', val, movedKeys); } else { this.$emit('checked-change', val); this.checkChangeByUser = true; } }, data: function data() { var _this = this; var checked = []; var filteredDataKeys = this.filteredData.map(function (item) { return item[_this.keyProp]; }); this.checked.forEach(function (item) { if (filteredDataKeys.indexOf(item) > -1) { checked.push(item); } }); this.checkChangeByUser = false; this.checked = checked; }, checkableData: function checkableData() { this.updateAllChecked(); }, defaultChecked: { immediate: true, handler: function handler(val, oldVal) { var _this2 = this; if (oldVal && val.length === oldVal.length && val.every(function (item) { return oldVal.indexOf(item) > -1; })) return; var checked = []; var checkableDataKeys = this.checkableData.map(function (item) { return item[_this2.keyProp]; }); val.forEach(function (item) { if (checkableDataKeys.indexOf(item) > -1) { checked.push(item); } }); this.checkChangeByUser = false; this.checked = checked; } } }, computed: { filteredData: function filteredData() { var _this3 = this; return this.data.filter(function (item) { if (typeof _this3.filterMethod === 'function') { return _this3.filterMethod(_this3.query, item); } else { var label = item[_this3.labelProp] || item[_this3.keyProp].toString(); return label.toLowerCase().indexOf(_this3.query.toLowerCase()) > -1; } }); }, checkableData: function checkableData() { var _this4 = this; return this.filteredData.filter(function (item) { return !item[_this4.disabledProp]; }); }, checkedSummary: function checkedSummary() { var checkedLength = this.checked.length; var dataLength = this.data.length; var _format = this.format, noChecked = _format.noChecked, hasChecked = _format.hasChecked; if (noChecked && hasChecked) { return checkedLength > 0 ? hasChecked.replace(/\${checked}/g, checkedLength).replace(/\${total}/g, dataLength) : noChecked.replace(/\${total}/g, dataLength); } else { return checkedLength + '/' + dataLength; } }, isIndeterminate: function isIndeterminate() { var checkedLength = this.checked.length; return checkedLength > 0 && checkedLength < this.checkableData.length; }, hasNoMatch: function hasNoMatch() { return this.query.length > 0 && this.filteredData.length === 0; }, inputIcon: function inputIcon() { return this.query.length > 0 && this.inputHover ? 'circle-close' : 'search'; }, labelProp: function labelProp() { return this.props.label || 'label'; }, keyProp: function keyProp() { return this.props.key || 'key'; }, disabledProp: function disabledProp() { return this.props.disabled || 'disabled'; }, hasFooter: function hasFooter() { return !!this.$slots.default; } }, methods: { updateAllChecked: function updateAllChecked() { var _this5 = this; var checkableDataKeys = this.checkableData.map(function (item) { return item[_this5.keyProp]; }); this.allChecked = checkableDataKeys.length > 0 && checkableDataKeys.every(function (item) { return _this5.checked.indexOf(item) > -1; }); }, handleAllCheckedChange: function handleAllCheckedChange(value) { var _this6 = this; this.checked = value ? this.checkableData.map(function (item) { return item[_this6.keyProp]; }) : []; }, clearQuery: function clearQuery() { if (this.inputIcon === 'circle-close') { this.query = ''; } } } }); // CONCATENATED MODULE: ./packages/transfer/src/transfer-panel.vue?vue&type=script&lang=js& /* harmony default export */ var src_transfer_panelvue_type_script_lang_js_ = (transfer_panelvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/transfer/src/transfer-panel.vue /* normalize component */ var transfer_panel_component = normalizeComponent( src_transfer_panelvue_type_script_lang_js_, transfer_panelvue_type_template_id_2ddab8bd_render, transfer_panelvue_type_template_id_2ddab8bd_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var transfer_panel_api; } transfer_panel_component.options.__file = "packages/transfer/src/transfer-panel.vue" /* harmony default export */ var transfer_panel = (transfer_panel_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/transfer/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var transfer_src_mainvue_type_script_lang_js_ = ({ name: 'ElTransfer', mixins: [emitter_default.a, locale_default.a, migrating_default.a], components: { TransferPanel: transfer_panel, ElButton: button_default.a }, props: { data: { type: Array, default: function _default() { return []; } }, titles: { type: Array, default: function _default() { return []; } }, buttonTexts: { type: Array, default: function _default() { return []; } }, filterPlaceholder: { type: String, default: '' }, filterMethod: Function, leftDefaultChecked: { type: Array, default: function _default() { return []; } }, rightDefaultChecked: { type: Array, default: function _default() { return []; } }, renderContent: Function, value: { type: Array, default: function _default() { return []; } }, format: { type: Object, default: function _default() { return {}; } }, filterable: Boolean, props: { type: Object, default: function _default() { return { label: 'label', key: 'key', disabled: 'disabled' }; } }, targetOrder: { type: String, default: 'original' } }, data: function data() { return { leftChecked: [], rightChecked: [] }; }, computed: { dataObj: function dataObj() { var key = this.props.key; return this.data.reduce(function (o, cur) { return (o[cur[key]] = cur) && o; }, {}); }, sourceData: function sourceData() { var _this = this; return this.data.filter(function (item) { return _this.value.indexOf(item[_this.props.key]) === -1; }); }, targetData: function targetData() { var _this2 = this; if (this.targetOrder === 'original') { return this.data.filter(function (item) { return _this2.value.indexOf(item[_this2.props.key]) > -1; }); } else { return this.value.reduce(function (arr, cur) { var val = _this2.dataObj[cur]; if (val) { arr.push(val); } return arr; }, []); } }, hasButtonTexts: function hasButtonTexts() { return this.buttonTexts.length === 2; } }, watch: { value: function value(val) { this.dispatch('ElFormItem', 'el.form.change', val); } }, methods: { getMigratingConfig: function getMigratingConfig() { return { props: { 'footer-format': 'footer-format is renamed to format.' } }; }, onSourceCheckedChange: function onSourceCheckedChange(val, movedKeys) { this.leftChecked = val; if (movedKeys === undefined) return; this.$emit('left-check-change', val, movedKeys); }, onTargetCheckedChange: function onTargetCheckedChange(val, movedKeys) { this.rightChecked = val; if (movedKeys === undefined) return; this.$emit('right-check-change', val, movedKeys); }, addToLeft: function addToLeft() { var currentValue = this.value.slice(); this.rightChecked.forEach(function (item) { var index = currentValue.indexOf(item); if (index > -1) { currentValue.splice(index, 1); } }); this.$emit('input', currentValue); this.$emit('change', currentValue, 'left', this.rightChecked); }, addToRight: function addToRight() { var _this3 = this; var currentValue = this.value.slice(); var itemsToBeMoved = []; var key = this.props.key; this.data.forEach(function (item) { var itemKey = item[key]; if (_this3.leftChecked.indexOf(itemKey) > -1 && _this3.value.indexOf(itemKey) === -1) { itemsToBeMoved.push(itemKey); } }); currentValue = this.targetOrder === 'unshift' ? itemsToBeMoved.concat(currentValue) : currentValue.concat(itemsToBeMoved); this.$emit('input', currentValue); this.$emit('change', currentValue, 'right', this.leftChecked); }, clearQuery: function clearQuery(which) { if (which === 'left') { this.$refs.leftPanel.query = ''; } else if (which === 'right') { this.$refs.rightPanel.query = ''; } } } }); // CONCATENATED MODULE: ./packages/transfer/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_transfer_src_mainvue_type_script_lang_js_ = (transfer_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/transfer/src/main.vue /* normalize component */ var transfer_src_main_component = normalizeComponent( packages_transfer_src_mainvue_type_script_lang_js_, mainvue_type_template_id_5c654dd8_render, mainvue_type_template_id_5c654dd8_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var transfer_src_main_api; } transfer_src_main_component.options.__file = "packages/transfer/src/main.vue" /* harmony default export */ var transfer_src_main = (transfer_src_main_component.exports); // CONCATENATED MODULE: ./packages/transfer/index.js /* istanbul ignore next */ transfer_src_main.install = function (Vue) { Vue.component(transfer_src_main.name, transfer_src_main); }; /* harmony default export */ var transfer = (transfer_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/container/src/main.vue?vue&type=template&id=5bf181d4& var mainvue_type_template_id_5bf181d4_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "section", { staticClass: "el-container", class: { "is-vertical": _vm.isVertical } }, [_vm._t("default")], 2 ) } var mainvue_type_template_id_5bf181d4_staticRenderFns = [] mainvue_type_template_id_5bf181d4_render._withStripped = true // CONCATENATED MODULE: ./packages/container/src/main.vue?vue&type=template&id=5bf181d4& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/container/src/main.vue?vue&type=script&lang=js& // // // // // // /* harmony default export */ var container_src_mainvue_type_script_lang_js_ = ({ name: 'ElContainer', componentName: 'ElContainer', props: { direction: String }, computed: { isVertical: function isVertical() { if (this.direction === 'vertical') { return true; } else if (this.direction === 'horizontal') { return false; } return this.$slots && this.$slots.default ? this.$slots.default.some(function (vnode) { var tag = vnode.componentOptions && vnode.componentOptions.tag; return tag === 'el-header' || tag === 'el-footer'; }) : false; } } }); // CONCATENATED MODULE: ./packages/container/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_container_src_mainvue_type_script_lang_js_ = (container_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/container/src/main.vue /* normalize component */ var container_src_main_component = normalizeComponent( packages_container_src_mainvue_type_script_lang_js_, mainvue_type_template_id_5bf181d4_render, mainvue_type_template_id_5bf181d4_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var container_src_main_api; } container_src_main_component.options.__file = "packages/container/src/main.vue" /* harmony default export */ var container_src_main = (container_src_main_component.exports); // CONCATENATED MODULE: ./packages/container/index.js /* istanbul ignore next */ container_src_main.install = function (Vue) { Vue.component(container_src_main.name, container_src_main); }; /* harmony default export */ var packages_container = (container_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/header/src/main.vue?vue&type=template&id=2b296ab2& var mainvue_type_template_id_2b296ab2_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "header", { staticClass: "el-header", style: { height: _vm.height } }, [_vm._t("default")], 2 ) } var mainvue_type_template_id_2b296ab2_staticRenderFns = [] mainvue_type_template_id_2b296ab2_render._withStripped = true // CONCATENATED MODULE: ./packages/header/src/main.vue?vue&type=template&id=2b296ab2& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/header/src/main.vue?vue&type=script&lang=js& // // // // // // /* harmony default export */ var header_src_mainvue_type_script_lang_js_ = ({ name: 'ElHeader', componentName: 'ElHeader', props: { height: { type: String, default: '60px' } } }); // CONCATENATED MODULE: ./packages/header/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_header_src_mainvue_type_script_lang_js_ = (header_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/header/src/main.vue /* normalize component */ var header_src_main_component = normalizeComponent( packages_header_src_mainvue_type_script_lang_js_, mainvue_type_template_id_2b296ab2_render, mainvue_type_template_id_2b296ab2_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var header_src_main_api; } header_src_main_component.options.__file = "packages/header/src/main.vue" /* harmony default export */ var header_src_main = (header_src_main_component.exports); // CONCATENATED MODULE: ./packages/header/index.js /* istanbul ignore next */ header_src_main.install = function (Vue) { Vue.component(header_src_main.name, header_src_main); }; /* harmony default export */ var header = (header_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/aside/src/main.vue?vue&type=template&id=03411dbf& var mainvue_type_template_id_03411dbf_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "aside", { staticClass: "el-aside", style: { width: _vm.width } }, [_vm._t("default")], 2 ) } var mainvue_type_template_id_03411dbf_staticRenderFns = [] mainvue_type_template_id_03411dbf_render._withStripped = true // CONCATENATED MODULE: ./packages/aside/src/main.vue?vue&type=template&id=03411dbf& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/aside/src/main.vue?vue&type=script&lang=js& // // // // // // /* harmony default export */ var aside_src_mainvue_type_script_lang_js_ = ({ name: 'ElAside', componentName: 'ElAside', props: { width: { type: String, default: '300px' } } }); // CONCATENATED MODULE: ./packages/aside/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_aside_src_mainvue_type_script_lang_js_ = (aside_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/aside/src/main.vue /* normalize component */ var aside_src_main_component = normalizeComponent( packages_aside_src_mainvue_type_script_lang_js_, mainvue_type_template_id_03411dbf_render, mainvue_type_template_id_03411dbf_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var aside_src_main_api; } aside_src_main_component.options.__file = "packages/aside/src/main.vue" /* harmony default export */ var aside_src_main = (aside_src_main_component.exports); // CONCATENATED MODULE: ./packages/aside/index.js /* istanbul ignore next */ aside_src_main.install = function (Vue) { Vue.component(aside_src_main.name, aside_src_main); }; /* harmony default export */ var aside = (aside_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/main/src/main.vue?vue&type=template&id=2a3a7406& var mainvue_type_template_id_2a3a7406_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("main", { staticClass: "el-main" }, [_vm._t("default")], 2) } var mainvue_type_template_id_2a3a7406_staticRenderFns = [] mainvue_type_template_id_2a3a7406_render._withStripped = true // CONCATENATED MODULE: ./packages/main/src/main.vue?vue&type=template&id=2a3a7406& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/main/src/main.vue?vue&type=script&lang=js& // // // // // // /* harmony default export */ var main_src_mainvue_type_script_lang_js_ = ({ name: 'ElMain', componentName: 'ElMain' }); // CONCATENATED MODULE: ./packages/main/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_main_src_mainvue_type_script_lang_js_ = (main_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/main/src/main.vue /* normalize component */ var main_src_main_component = normalizeComponent( packages_main_src_mainvue_type_script_lang_js_, mainvue_type_template_id_2a3a7406_render, mainvue_type_template_id_2a3a7406_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var main_src_main_api; } main_src_main_component.options.__file = "packages/main/src/main.vue" /* harmony default export */ var main_src_main = (main_src_main_component.exports); // CONCATENATED MODULE: ./packages/main/index.js /* istanbul ignore next */ main_src_main.install = function (Vue) { Vue.component(main_src_main.name, main_src_main); }; /* harmony default export */ var packages_main = (main_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/footer/src/main.vue?vue&type=template&id=80210338& var mainvue_type_template_id_80210338_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "footer", { staticClass: "el-footer", style: { height: _vm.height } }, [_vm._t("default")], 2 ) } var mainvue_type_template_id_80210338_staticRenderFns = [] mainvue_type_template_id_80210338_render._withStripped = true // CONCATENATED MODULE: ./packages/footer/src/main.vue?vue&type=template&id=80210338& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/footer/src/main.vue?vue&type=script&lang=js& // // // // // // /* harmony default export */ var footer_src_mainvue_type_script_lang_js_ = ({ name: 'ElFooter', componentName: 'ElFooter', props: { height: { type: String, default: '60px' } } }); // CONCATENATED MODULE: ./packages/footer/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_footer_src_mainvue_type_script_lang_js_ = (footer_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/footer/src/main.vue /* normalize component */ var footer_src_main_component = normalizeComponent( packages_footer_src_mainvue_type_script_lang_js_, mainvue_type_template_id_80210338_render, mainvue_type_template_id_80210338_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var footer_src_main_api; } footer_src_main_component.options.__file = "packages/footer/src/main.vue" /* harmony default export */ var footer_src_main = (footer_src_main_component.exports); // CONCATENATED MODULE: ./packages/footer/index.js /* istanbul ignore next */ footer_src_main.install = function (Vue) { Vue.component(footer_src_main.name, footer_src_main); }; /* harmony default export */ var footer = (footer_src_main); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/timeline/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var timeline_src_mainvue_type_script_lang_js_ = ({ name: 'ElTimeline', props: { reverse: { type: Boolean, default: false } }, provide: function provide() { return { timeline: this }; }, render: function render() { var h = arguments[0]; var reverse = this.reverse; var classes = { 'el-timeline': true, 'is-reverse': reverse }; var slots = this.$slots.default || []; if (reverse) { slots = slots.reverse(); } return h( 'ul', { 'class': classes }, [slots] ); } }); // CONCATENATED MODULE: ./packages/timeline/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_timeline_src_mainvue_type_script_lang_js_ = (timeline_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/timeline/src/main.vue var main_render, main_staticRenderFns /* normalize component */ var timeline_src_main_component = normalizeComponent( packages_timeline_src_mainvue_type_script_lang_js_, main_render, main_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var timeline_src_main_api; } timeline_src_main_component.options.__file = "packages/timeline/src/main.vue" /* harmony default export */ var timeline_src_main = (timeline_src_main_component.exports); // CONCATENATED MODULE: ./packages/timeline/index.js /* istanbul ignore next */ timeline_src_main.install = function (Vue) { Vue.component(timeline_src_main.name, timeline_src_main); }; /* harmony default export */ var timeline = (timeline_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/timeline/src/item.vue?vue&type=template&id=61a69e50& var itemvue_type_template_id_61a69e50_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("li", { staticClass: "el-timeline-item" }, [ _c("div", { staticClass: "el-timeline-item__tail" }), !_vm.$slots.dot ? _c( "div", { staticClass: "el-timeline-item__node", class: [ "el-timeline-item__node--" + (_vm.size || ""), "el-timeline-item__node--" + (_vm.type || "") ], style: { backgroundColor: _vm.color } }, [ _vm.icon ? _c("i", { staticClass: "el-timeline-item__icon", class: _vm.icon }) : _vm._e() ] ) : _vm._e(), _vm.$slots.dot ? _c("div", { staticClass: "el-timeline-item__dot" }, [_vm._t("dot")], 2) : _vm._e(), _c("div", { staticClass: "el-timeline-item__wrapper" }, [ !_vm.hideTimestamp && _vm.placement === "top" ? _c("div", { staticClass: "el-timeline-item__timestamp is-top" }, [ _vm._v("\n " + _vm._s(_vm.timestamp) + "\n ") ]) : _vm._e(), _c( "div", { staticClass: "el-timeline-item__content" }, [_vm._t("default")], 2 ), !_vm.hideTimestamp && _vm.placement === "bottom" ? _c("div", { staticClass: "el-timeline-item__timestamp is-bottom" }, [ _vm._v("\n " + _vm._s(_vm.timestamp) + "\n ") ]) : _vm._e() ]) ]) } var itemvue_type_template_id_61a69e50_staticRenderFns = [] itemvue_type_template_id_61a69e50_render._withStripped = true // CONCATENATED MODULE: ./packages/timeline/src/item.vue?vue&type=template&id=61a69e50& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/timeline/src/item.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var timeline_src_itemvue_type_script_lang_js_ = ({ name: 'ElTimelineItem', inject: ['timeline'], props: { timestamp: String, hideTimestamp: { type: Boolean, default: false }, placement: { type: String, default: 'bottom' }, type: String, color: String, size: { type: String, default: 'normal' }, icon: String } }); // CONCATENATED MODULE: ./packages/timeline/src/item.vue?vue&type=script&lang=js& /* harmony default export */ var packages_timeline_src_itemvue_type_script_lang_js_ = (timeline_src_itemvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/timeline/src/item.vue /* normalize component */ var src_item_component = normalizeComponent( packages_timeline_src_itemvue_type_script_lang_js_, itemvue_type_template_id_61a69e50_render, itemvue_type_template_id_61a69e50_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var src_item_api; } src_item_component.options.__file = "packages/timeline/src/item.vue" /* harmony default export */ var timeline_src_item = (src_item_component.exports); // CONCATENATED MODULE: ./packages/timeline-item/index.js /* istanbul ignore next */ timeline_src_item.install = function (Vue) { Vue.component(timeline_src_item.name, timeline_src_item); }; /* harmony default export */ var timeline_item = (timeline_src_item); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/link/src/main.vue?vue&type=template&id=01cf3b65& var mainvue_type_template_id_01cf3b65_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "a", _vm._b( { class: [ "el-link", _vm.type ? "el-link--" + _vm.type : "", _vm.disabled && "is-disabled", _vm.underline && !_vm.disabled && "is-underline" ], attrs: { href: _vm.disabled ? null : _vm.href }, on: { click: _vm.handleClick } }, "a", _vm.$attrs, false ), [ _vm.icon ? _c("i", { class: _vm.icon }) : _vm._e(), _vm.$slots.default ? _c("span", { staticClass: "el-link--inner" }, [_vm._t("default")], 2) : _vm._e(), _vm.$slots.icon ? [_vm.$slots.icon ? _vm._t("icon") : _vm._e()] : _vm._e() ], 2 ) } var mainvue_type_template_id_01cf3b65_staticRenderFns = [] mainvue_type_template_id_01cf3b65_render._withStripped = true // CONCATENATED MODULE: ./packages/link/src/main.vue?vue&type=template&id=01cf3b65& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/link/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var link_src_mainvue_type_script_lang_js_ = ({ name: 'ElLink', props: { type: { type: String, default: 'default' }, underline: { type: Boolean, default: true }, disabled: Boolean, href: String, icon: String }, methods: { handleClick: function handleClick(event) { if (!this.disabled) { if (!this.href) { this.$emit('click', event); } } } } }); // CONCATENATED MODULE: ./packages/link/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_link_src_mainvue_type_script_lang_js_ = (link_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/link/src/main.vue /* normalize component */ var link_src_main_component = normalizeComponent( packages_link_src_mainvue_type_script_lang_js_, mainvue_type_template_id_01cf3b65_render, mainvue_type_template_id_01cf3b65_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var link_src_main_api; } link_src_main_component.options.__file = "packages/link/src/main.vue" /* harmony default export */ var link_src_main = (link_src_main_component.exports); // CONCATENATED MODULE: ./packages/link/index.js /* istanbul ignore next */ link_src_main.install = function (Vue) { Vue.component(link_src_main.name, link_src_main); }; /* harmony default export */ var packages_link = (link_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/divider/src/main.vue?vue&type=template&id=7fa02a7e&functional=true& var mainvue_type_template_id_7fa02a7e_functional_true_render = function(_h, _vm) { var _c = _vm._c return _c( "div", _vm._g( _vm._b( { class: [ _vm.data.staticClass, "el-divider", "el-divider--" + _vm.props.direction ] }, "div", _vm.data.attrs, false ), _vm.listeners ), [ _vm.slots().default && _vm.props.direction !== "vertical" ? _c( "div", { class: ["el-divider__text", "is-" + _vm.props.contentPosition] }, [_vm._t("default")], 2 ) : _vm._e() ] ) } var mainvue_type_template_id_7fa02a7e_functional_true_staticRenderFns = [] mainvue_type_template_id_7fa02a7e_functional_true_render._withStripped = true // CONCATENATED MODULE: ./packages/divider/src/main.vue?vue&type=template&id=7fa02a7e&functional=true& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/divider/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // /* harmony default export */ var divider_src_mainvue_type_script_lang_js_ = ({ name: 'ElDivider', props: { direction: { type: String, default: 'horizontal', validator: function validator(val) { return ['horizontal', 'vertical'].indexOf(val) !== -1; } }, contentPosition: { type: String, default: 'center', validator: function validator(val) { return ['left', 'center', 'right'].indexOf(val) !== -1; } } } }); // CONCATENATED MODULE: ./packages/divider/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_divider_src_mainvue_type_script_lang_js_ = (divider_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/divider/src/main.vue /* normalize component */ var divider_src_main_component = normalizeComponent( packages_divider_src_mainvue_type_script_lang_js_, mainvue_type_template_id_7fa02a7e_functional_true_render, mainvue_type_template_id_7fa02a7e_functional_true_staticRenderFns, true, null, null, null ) /* hot reload */ if (false) { var divider_src_main_api; } divider_src_main_component.options.__file = "packages/divider/src/main.vue" /* harmony default export */ var divider_src_main = (divider_src_main_component.exports); // CONCATENATED MODULE: ./packages/divider/index.js /* istanbul ignore next */ divider_src_main.install = function (Vue) { Vue.component(divider_src_main.name, divider_src_main); }; /* harmony default export */ var divider = (divider_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/image/src/main.vue?vue&type=template&id=44d84a7c& var mainvue_type_template_id_44d84a7c_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { staticClass: "el-image" }, [ _vm.loading ? _vm._t("placeholder", [ _c("div", { staticClass: "el-image__placeholder" }) ]) : _vm.error ? _vm._t("error", [ _c("div", { staticClass: "el-image__error" }, [ _vm._v(_vm._s(_vm.t("el.image.error"))) ]) ]) : _c( "img", _vm._g( _vm._b( { staticClass: "el-image__inner", class: { "el-image__inner--center": _vm.alignCenter, "el-image__preview": _vm.preview }, style: _vm.imageStyle, attrs: { src: _vm.src }, on: { click: _vm.clickHandler } }, "img", _vm.$attrs, false ), _vm.$listeners ) ), _vm.preview ? [ _vm.showViewer ? _c("image-viewer", { attrs: { "z-index": _vm.zIndex, "initial-index": _vm.imageIndex, "on-close": _vm.closeViewer, "url-list": _vm.previewSrcList } }) : _vm._e() ] : _vm._e() ], 2 ) } var mainvue_type_template_id_44d84a7c_staticRenderFns = [] mainvue_type_template_id_44d84a7c_render._withStripped = true // CONCATENATED MODULE: ./packages/image/src/main.vue?vue&type=template&id=44d84a7c& // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/image/src/image-viewer.vue?vue&type=template&id=5e73b307& var image_viewervue_type_template_id_5e73b307_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("transition", { attrs: { name: "viewer-fade" } }, [ _c( "div", { ref: "el-image-viewer__wrapper", staticClass: "el-image-viewer__wrapper", style: { "z-index": _vm.zIndex }, attrs: { tabindex: "-1" } }, [ _c("div", { staticClass: "el-image-viewer__mask" }), _c( "span", { staticClass: "el-image-viewer__btn el-image-viewer__close", on: { click: _vm.hide } }, [_c("i", { staticClass: "el-icon-circle-close" })] ), !_vm.isSingle ? [ _c( "span", { staticClass: "el-image-viewer__btn el-image-viewer__prev", class: { "is-disabled": !_vm.infinite && _vm.isFirst }, on: { click: _vm.prev } }, [_c("i", { staticClass: "el-icon-arrow-left" })] ), _c( "span", { staticClass: "el-image-viewer__btn el-image-viewer__next", class: { "is-disabled": !_vm.infinite && _vm.isLast }, on: { click: _vm.next } }, [_c("i", { staticClass: "el-icon-arrow-right" })] ) ] : _vm._e(), _c( "div", { staticClass: "el-image-viewer__btn el-image-viewer__actions" }, [ _c("div", { staticClass: "el-image-viewer__actions__inner" }, [ _c("i", { staticClass: "el-icon-zoom-out", on: { click: function($event) { _vm.handleActions("zoomOut") } } }), _c("i", { staticClass: "el-icon-zoom-in", on: { click: function($event) { _vm.handleActions("zoomIn") } } }), _c("i", { staticClass: "el-image-viewer__actions__divider" }), _c("i", { class: _vm.mode.icon, on: { click: _vm.toggleMode } }), _c("i", { staticClass: "el-image-viewer__actions__divider" }), _c("i", { staticClass: "el-icon-refresh-left", on: { click: function($event) { _vm.handleActions("anticlocelise") } } }), _c("i", { staticClass: "el-icon-refresh-right", on: { click: function($event) { _vm.handleActions("clocelise") } } }) ]) ] ), _c( "div", { staticClass: "el-image-viewer__canvas" }, _vm._l(_vm.urlList, function(url, i) { return i === _vm.index ? _c("img", { key: url, ref: "img", refInFor: true, staticClass: "el-image-viewer__img", style: _vm.imgStyle, attrs: { src: _vm.currentImg }, on: { load: _vm.handleImgLoad, error: _vm.handleImgError, mousedown: _vm.handleMouseDown } }) : _vm._e() }), 0 ) ], 2 ) ]) } var image_viewervue_type_template_id_5e73b307_staticRenderFns = [] image_viewervue_type_template_id_5e73b307_render._withStripped = true // CONCATENATED MODULE: ./packages/image/src/image-viewer.vue?vue&type=template&id=5e73b307& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/image/src/image-viewer.vue?vue&type=script&lang=js& var image_viewervue_type_script_lang_js_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var Mode = { CONTAIN: { name: 'contain', icon: 'el-icon-full-screen' }, ORIGINAL: { name: 'original', icon: 'el-icon-c-scale-to-original' } }; var mousewheelEventName = Object(util_["isFirefox"])() ? 'DOMMouseScroll' : 'mousewheel'; /* harmony default export */ var image_viewervue_type_script_lang_js_ = ({ name: 'elImageViewer', props: { urlList: { type: Array, default: function _default() { return []; } }, zIndex: { type: Number, default: 2000 }, onSwitch: { type: Function, default: function _default() {} }, onClose: { type: Function, default: function _default() {} }, initialIndex: { type: Number, default: 0 } }, data: function data() { return { index: this.initialIndex, isShow: false, infinite: true, loading: false, mode: Mode.CONTAIN, transform: { scale: 1, deg: 0, offsetX: 0, offsetY: 0, enableTransition: false } }; }, computed: { isSingle: function isSingle() { return this.urlList.length <= 1; }, isFirst: function isFirst() { return this.index === 0; }, isLast: function isLast() { return this.index === this.urlList.length - 1; }, currentImg: function currentImg() { return this.urlList[this.index]; }, imgStyle: function imgStyle() { var _transform = this.transform, scale = _transform.scale, deg = _transform.deg, offsetX = _transform.offsetX, offsetY = _transform.offsetY, enableTransition = _transform.enableTransition; var style = { transform: 'scale(' + scale + ') rotate(' + deg + 'deg)', transition: enableTransition ? 'transform .3s' : '', 'margin-left': offsetX + 'px', 'margin-top': offsetY + 'px' }; if (this.mode === Mode.CONTAIN) { style.maxWidth = style.maxHeight = '100%'; } return style; } }, watch: { index: { handler: function handler(val) { this.reset(); this.onSwitch(val); } }, currentImg: function currentImg(val) { var _this = this; this.$nextTick(function (_) { var $img = _this.$refs.img[0]; if (!$img.complete) { _this.loading = true; } }); } }, methods: { hide: function hide() { this.deviceSupportUninstall(); this.onClose(); }, deviceSupportInstall: function deviceSupportInstall() { var _this2 = this; this._keyDownHandler = Object(util_["rafThrottle"])(function (e) { var keyCode = e.keyCode; switch (keyCode) { // ESC case 27: _this2.hide(); break; // SPACE case 32: _this2.toggleMode(); break; // LEFT_ARROW case 37: _this2.prev(); break; // UP_ARROW case 38: _this2.handleActions('zoomIn'); break; // RIGHT_ARROW case 39: _this2.next(); break; // DOWN_ARROW case 40: _this2.handleActions('zoomOut'); break; } }); this._mouseWheelHandler = Object(util_["rafThrottle"])(function (e) { var delta = e.wheelDelta ? e.wheelDelta : -e.detail; if (delta > 0) { _this2.handleActions('zoomIn', { zoomRate: 0.015, enableTransition: false }); } else { _this2.handleActions('zoomOut', { zoomRate: 0.015, enableTransition: false }); } }); Object(dom_["on"])(document, 'keydown', this._keyDownHandler); Object(dom_["on"])(document, mousewheelEventName, this._mouseWheelHandler); }, deviceSupportUninstall: function deviceSupportUninstall() { Object(dom_["off"])(document, 'keydown', this._keyDownHandler); Object(dom_["off"])(document, mousewheelEventName, this._mouseWheelHandler); this._keyDownHandler = null; this._mouseWheelHandler = null; }, handleImgLoad: function handleImgLoad(e) { this.loading = false; }, handleImgError: function handleImgError(e) { this.loading = false; e.target.alt = '加载失败'; }, handleMouseDown: function handleMouseDown(e) { var _this3 = this; if (this.loading || e.button !== 0) return; var _transform2 = this.transform, offsetX = _transform2.offsetX, offsetY = _transform2.offsetY; var startX = e.pageX; var startY = e.pageY; this._dragHandler = Object(util_["rafThrottle"])(function (ev) { _this3.transform.offsetX = offsetX + ev.pageX - startX; _this3.transform.offsetY = offsetY + ev.pageY - startY; }); Object(dom_["on"])(document, 'mousemove', this._dragHandler); Object(dom_["on"])(document, 'mouseup', function (ev) { Object(dom_["off"])(document, 'mousemove', _this3._dragHandler); }); e.preventDefault(); }, reset: function reset() { this.transform = { scale: 1, deg: 0, offsetX: 0, offsetY: 0, enableTransition: false }; }, toggleMode: function toggleMode() { if (this.loading) return; var modeNames = Object.keys(Mode); var modeValues = Object.values(Mode); var index = modeValues.indexOf(this.mode); var nextIndex = (index + 1) % modeNames.length; this.mode = Mode[modeNames[nextIndex]]; this.reset(); }, prev: function prev() { if (this.isFirst && !this.infinite) return; var len = this.urlList.length; this.index = (this.index - 1 + len) % len; }, next: function next() { if (this.isLast && !this.infinite) return; var len = this.urlList.length; this.index = (this.index + 1) % len; }, handleActions: function handleActions(action) { var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; if (this.loading) return; var _zoomRate$rotateDeg$e = image_viewervue_type_script_lang_js_extends({ zoomRate: 0.2, rotateDeg: 90, enableTransition: true }, options), zoomRate = _zoomRate$rotateDeg$e.zoomRate, rotateDeg = _zoomRate$rotateDeg$e.rotateDeg, enableTransition = _zoomRate$rotateDeg$e.enableTransition; var transform = this.transform; switch (action) { case 'zoomOut': if (transform.scale > 0.2) { transform.scale = parseFloat((transform.scale - zoomRate).toFixed(3)); } break; case 'zoomIn': transform.scale = parseFloat((transform.scale + zoomRate).toFixed(3)); break; case 'clocelise': transform.deg += rotateDeg; break; case 'anticlocelise': transform.deg -= rotateDeg; break; } transform.enableTransition = enableTransition; } }, mounted: function mounted() { this.deviceSupportInstall(); // add tabindex then wrapper can be focusable via Javascript // focus wrapper so arrow key can't cause inner scroll behavior underneath this.$refs['el-image-viewer__wrapper'].focus(); } }); // CONCATENATED MODULE: ./packages/image/src/image-viewer.vue?vue&type=script&lang=js& /* harmony default export */ var src_image_viewervue_type_script_lang_js_ = (image_viewervue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/image/src/image-viewer.vue /* normalize component */ var image_viewer_component = normalizeComponent( src_image_viewervue_type_script_lang_js_, image_viewervue_type_template_id_5e73b307_render, image_viewervue_type_template_id_5e73b307_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var image_viewer_api; } image_viewer_component.options.__file = "packages/image/src/image-viewer.vue" /* harmony default export */ var image_viewer = (image_viewer_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/image/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // var isSupportObjectFit = function isSupportObjectFit() { return document.documentElement.style.objectFit !== undefined; }; var ObjectFit = { NONE: 'none', CONTAIN: 'contain', COVER: 'cover', FILL: 'fill', SCALE_DOWN: 'scale-down' }; var prevOverflow = ''; /* harmony default export */ var image_src_mainvue_type_script_lang_js_ = ({ name: 'ElImage', mixins: [locale_default.a], inheritAttrs: false, components: { ImageViewer: image_viewer }, props: { src: String, fit: String, lazy: Boolean, scrollContainer: {}, previewSrcList: { type: Array, default: function _default() { return []; } }, zIndex: { type: Number, default: 2000 } }, data: function data() { return { loading: true, error: false, show: !this.lazy, imageWidth: 0, imageHeight: 0, showViewer: false }; }, computed: { imageStyle: function imageStyle() { var fit = this.fit; if (!this.$isServer && fit) { return isSupportObjectFit() ? { 'object-fit': fit } : this.getImageStyle(fit); } return {}; }, alignCenter: function alignCenter() { return !this.$isServer && !isSupportObjectFit() && this.fit !== ObjectFit.FILL; }, preview: function preview() { var previewSrcList = this.previewSrcList; return Array.isArray(previewSrcList) && previewSrcList.length > 0; }, imageIndex: function imageIndex() { var previewIndex = 0; var srcIndex = this.previewSrcList.indexOf(this.src); if (srcIndex >= 0) { previewIndex = srcIndex; } return previewIndex; } }, watch: { src: function src(val) { this.show && this.loadImage(); }, show: function show(val) { val && this.loadImage(); } }, mounted: function mounted() { if (this.lazy) { this.addLazyLoadListener(); } else { this.loadImage(); } }, beforeDestroy: function beforeDestroy() { this.lazy && this.removeLazyLoadListener(); }, methods: { loadImage: function loadImage() { var _this = this; if (this.$isServer) return; // reset status this.loading = true; this.error = false; var img = new Image(); img.onload = function (e) { return _this.handleLoad(e, img); }; img.onerror = this.handleError.bind(this); // bind html attrs // so it can behave consistently Object.keys(this.$attrs).forEach(function (key) { var value = _this.$attrs[key]; img.setAttribute(key, value); }); img.src = this.src; }, handleLoad: function handleLoad(e, img) { this.imageWidth = img.width; this.imageHeight = img.height; this.loading = false; this.error = false; }, handleError: function handleError(e) { this.loading = false; this.error = true; this.$emit('error', e); }, handleLazyLoad: function handleLazyLoad() { if (Object(dom_["isInContainer"])(this.$el, this._scrollContainer)) { this.show = true; this.removeLazyLoadListener(); } }, addLazyLoadListener: function addLazyLoadListener() { if (this.$isServer) return; var scrollContainer = this.scrollContainer; var _scrollContainer = null; if (Object(types_["isHtmlElement"])(scrollContainer)) { _scrollContainer = scrollContainer; } else if (Object(types_["isString"])(scrollContainer)) { _scrollContainer = document.querySelector(scrollContainer); } else { _scrollContainer = Object(dom_["getScrollContainer"])(this.$el); } if (_scrollContainer) { this._scrollContainer = _scrollContainer; this._lazyLoadHandler = throttle_default()(200, this.handleLazyLoad); Object(dom_["on"])(_scrollContainer, 'scroll', this._lazyLoadHandler); this.handleLazyLoad(); } }, removeLazyLoadListener: function removeLazyLoadListener() { var _scrollContainer = this._scrollContainer, _lazyLoadHandler = this._lazyLoadHandler; if (this.$isServer || !_scrollContainer || !_lazyLoadHandler) return; Object(dom_["off"])(_scrollContainer, 'scroll', _lazyLoadHandler); this._scrollContainer = null; this._lazyLoadHandler = null; }, /** * simulate object-fit behavior to compatible with IE11 and other browsers which not support object-fit */ getImageStyle: function getImageStyle(fit) { var imageWidth = this.imageWidth, imageHeight = this.imageHeight; var _$el = this.$el, containerWidth = _$el.clientWidth, containerHeight = _$el.clientHeight; if (!imageWidth || !imageHeight || !containerWidth || !containerHeight) return {}; var vertical = imageWidth / imageHeight < 1; if (fit === ObjectFit.SCALE_DOWN) { var isSmaller = imageWidth < containerWidth && imageHeight < containerHeight; fit = isSmaller ? ObjectFit.NONE : ObjectFit.CONTAIN; } switch (fit) { case ObjectFit.NONE: return { width: 'auto', height: 'auto' }; case ObjectFit.CONTAIN: return vertical ? { width: 'auto' } : { height: 'auto' }; case ObjectFit.COVER: return vertical ? { height: 'auto' } : { width: 'auto' }; default: return {}; } }, clickHandler: function clickHandler() { // don't show viewer when preview is false if (!this.preview) { return; } // prevent body scroll prevOverflow = document.body.style.overflow; document.body.style.overflow = 'hidden'; this.showViewer = true; }, closeViewer: function closeViewer() { document.body.style.overflow = prevOverflow; this.showViewer = false; } } }); // CONCATENATED MODULE: ./packages/image/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_image_src_mainvue_type_script_lang_js_ = (image_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/image/src/main.vue /* normalize component */ var image_src_main_component = normalizeComponent( packages_image_src_mainvue_type_script_lang_js_, mainvue_type_template_id_44d84a7c_render, mainvue_type_template_id_44d84a7c_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var image_src_main_api; } image_src_main_component.options.__file = "packages/image/src/main.vue" /* harmony default export */ var image_src_main = (image_src_main_component.exports); // CONCATENATED MODULE: ./packages/image/index.js /* istanbul ignore next */ image_src_main.install = function (Vue) { Vue.component(image_src_main.name, image_src_main); }; /* harmony default export */ var packages_image = (image_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/calendar/src/main.vue?vue&type=template&id=6d9756be& var mainvue_type_template_id_6d9756be_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("div", { staticClass: "el-calendar" }, [ _c("div", { staticClass: "el-calendar__header" }, [ _c("div", { staticClass: "el-calendar__title" }, [ _vm._v("\n " + _vm._s(_vm.i18nDate) + "\n ") ]), _vm.validatedRange.length === 0 ? _c( "div", { staticClass: "el-calendar__button-group" }, [ _c( "el-button-group", [ _c( "el-button", { attrs: { type: "plain", size: "mini" }, on: { click: function($event) { _vm.selectDate("prev-month") } } }, [ _vm._v( "\n " + _vm._s(_vm.t("el.datepicker.prevMonth")) + "\n " ) ] ), _c( "el-button", { attrs: { type: "plain", size: "mini" }, on: { click: function($event) { _vm.selectDate("today") } } }, [ _vm._v( "\n " + _vm._s(_vm.t("el.datepicker.today")) + "\n " ) ] ), _c( "el-button", { attrs: { type: "plain", size: "mini" }, on: { click: function($event) { _vm.selectDate("next-month") } } }, [ _vm._v( "\n " + _vm._s(_vm.t("el.datepicker.nextMonth")) + "\n " ) ] ) ], 1 ) ], 1 ) : _vm._e() ]), _vm.validatedRange.length === 0 ? _c( "div", { key: "no-range", staticClass: "el-calendar__body" }, [ _c("date-table", { attrs: { date: _vm.date, "selected-day": _vm.realSelectedDay, "first-day-of-week": _vm.realFirstDayOfWeek }, on: { pick: _vm.pickDay } }) ], 1 ) : _c( "div", { key: "has-range", staticClass: "el-calendar__body" }, _vm._l(_vm.validatedRange, function(range, index) { return _c("date-table", { key: index, attrs: { date: range[0], "selected-day": _vm.realSelectedDay, range: range, "hide-header": index !== 0, "first-day-of-week": _vm.realFirstDayOfWeek }, on: { pick: _vm.pickDay } }) }), 1 ) ]) } var mainvue_type_template_id_6d9756be_staticRenderFns = [] mainvue_type_template_id_6d9756be_render._withStripped = true // CONCATENATED MODULE: ./packages/calendar/src/main.vue?vue&type=template&id=6d9756be& // EXTERNAL MODULE: external "element-ui/lib/utils/date" var date_ = __webpack_require__(20); var date_default = /*#__PURE__*/__webpack_require__.n(date_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/calendar/src/date-table.vue?vue&type=script&lang=js& /* harmony default export */ var src_date_tablevue_type_script_lang_js_ = ({ props: { selectedDay: String, // formated date yyyy-MM-dd range: { type: Array, validator: function validator(val) { if (!(val && val.length)) return true; var start = val[0], end = val[1]; return Object(date_util_["validateRangeInOneMonth"])(start, end); } }, date: Date, hideHeader: Boolean, firstDayOfWeek: Number }, inject: ['elCalendar'], data: function data() { return { WEEK_DAYS: Object(date_util_["getI18nSettings"])().dayNames }; }, methods: { toNestedArr: function toNestedArr(days) { return Object(date_util_["range"])(days.length / 7).map(function (_, index) { var start = index * 7; return days.slice(start, start + 7); }); }, getFormateDate: function getFormateDate(day, type) { if (!day || ['prev', 'current', 'next'].indexOf(type) === -1) { throw new Error('invalid day or type'); } var prefix = this.curMonthDatePrefix; if (type === 'prev') { prefix = this.prevMonthDatePrefix; } else if (type === 'next') { prefix = this.nextMonthDatePrefix; } day = ('00' + day).slice(-2); return prefix + '-' + day; }, getCellClass: function getCellClass(_ref) { var text = _ref.text, type = _ref.type; var classes = [type]; if (type === 'current') { var date = this.getFormateDate(text, type); if (date === this.selectedDay) { classes.push('is-selected'); } if (date === this.formatedToday) { classes.push('is-today'); } } return classes; }, pickDay: function pickDay(_ref2) { var text = _ref2.text, type = _ref2.type; var date = this.getFormateDate(text, type); this.$emit('pick', date); }, cellRenderProxy: function cellRenderProxy(_ref3) { var text = _ref3.text, type = _ref3.type; var h = this.$createElement; var render = this.elCalendar.$scopedSlots.dateCell; if (!render) return h('span', [text]); var day = this.getFormateDate(text, type); var date = new Date(day); var data = { isSelected: this.selectedDay === day, type: type + '-month', day: day }; return render({ date: date, data: data }); } }, computed: { prevMonthDatePrefix: function prevMonthDatePrefix() { var temp = new Date(this.date.getTime()); temp.setDate(0); return date_default.a.format(temp, 'yyyy-MM'); }, curMonthDatePrefix: function curMonthDatePrefix() { return date_default.a.format(this.date, 'yyyy-MM'); }, nextMonthDatePrefix: function nextMonthDatePrefix() { var temp = new Date(this.date.getFullYear(), this.date.getMonth() + 1, 1); return date_default.a.format(temp, 'yyyy-MM'); }, formatedToday: function formatedToday() { return this.elCalendar.formatedToday; }, isInRange: function isInRange() { return this.range && this.range.length; }, rows: function rows() { var days = []; // if range exists, should render days in range. if (this.isInRange) { var _range = this.range, start = _range[0], end = _range[1]; var currentMonthRange = Object(date_util_["range"])(end.getDate() - start.getDate() + 1).map(function (_, index) { return { text: start.getDate() + index, type: 'current' }; }); var remaining = currentMonthRange.length % 7; remaining = remaining === 0 ? 0 : 7 - remaining; var nextMonthRange = Object(date_util_["range"])(remaining).map(function (_, index) { return { text: index + 1, type: 'next' }; }); days = currentMonthRange.concat(nextMonthRange); } else { var date = this.date; var firstDay = Object(date_util_["getFirstDayOfMonth"])(date); firstDay = firstDay === 0 ? 7 : firstDay; var firstDayOfWeek = typeof this.firstDayOfWeek === 'number' ? this.firstDayOfWeek : 1; var prevMonthDays = Object(date_util_["getPrevMonthLastDays"])(date, firstDay - firstDayOfWeek).map(function (day) { return { text: day, type: 'prev' }; }); var currentMonthDays = Object(date_util_["getMonthDays"])(date).map(function (day) { return { text: day, type: 'current' }; }); days = [].concat(prevMonthDays, currentMonthDays); var nextMonthDays = Object(date_util_["range"])(42 - days.length).map(function (_, index) { return { text: index + 1, type: 'next' }; }); days = days.concat(nextMonthDays); } return this.toNestedArr(days); }, weekDays: function weekDays() { var start = this.firstDayOfWeek; var WEEK_DAYS = this.WEEK_DAYS; if (typeof start !== 'number' || start === 0) { return WEEK_DAYS.slice(); } else { return WEEK_DAYS.slice(start).concat(WEEK_DAYS.slice(0, start)); } } }, render: function render() { var _this = this; var h = arguments[0]; var thead = this.hideHeader ? null : h('thead', [this.weekDays.map(function (day) { return h( 'th', { key: day }, [day] ); })]); return h( 'table', { 'class': { 'el-calendar-table': true, 'is-range': this.isInRange }, attrs: { cellspacing: '0', cellpadding: '0' } }, [thead, h('tbody', [this.rows.map(function (row, index) { return h( 'tr', { 'class': { 'el-calendar-table__row': true, 'el-calendar-table__row--hide-border': index === 0 && _this.hideHeader }, key: index }, [row.map(function (cell, key) { return h( 'td', { key: key, 'class': _this.getCellClass(cell), on: { 'click': _this.pickDay.bind(_this, cell) } }, [h( 'div', { 'class': 'el-calendar-day' }, [_this.cellRenderProxy(cell)] )] ); })] ); })])] ); } }); // CONCATENATED MODULE: ./packages/calendar/src/date-table.vue?vue&type=script&lang=js& /* harmony default export */ var calendar_src_date_tablevue_type_script_lang_js_ = (src_date_tablevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/calendar/src/date-table.vue var date_table_render, date_table_staticRenderFns /* normalize component */ var src_date_table_component = normalizeComponent( calendar_src_date_tablevue_type_script_lang_js_, date_table_render, date_table_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var src_date_table_api; } src_date_table_component.options.__file = "packages/calendar/src/date-table.vue" /* harmony default export */ var src_date_table = (src_date_table_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/calendar/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // var validTypes = ['prev-month', 'today', 'next-month']; var weekDays = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday']; var oneDay = 86400000; /* harmony default export */ var calendar_src_mainvue_type_script_lang_js_ = ({ name: 'ElCalendar', mixins: [locale_default.a], components: { DateTable: src_date_table, ElButton: button_default.a, ElButtonGroup: button_group_default.a }, props: { value: [Date, String, Number], range: { type: Array, validator: function validator(range) { if (Array.isArray(range)) { return range.length === 2 && range.every(function (item) { return typeof item === 'string' || typeof item === 'number' || item instanceof Date; }); } else { return true; } } }, firstDayOfWeek: { type: Number, default: 1 } }, provide: function provide() { return { elCalendar: this }; }, methods: { pickDay: function pickDay(day) { this.realSelectedDay = day; }, selectDate: function selectDate(type) { if (validTypes.indexOf(type) === -1) { throw new Error('invalid type ' + type); } var day = ''; if (type === 'prev-month') { day = this.prevMonthDatePrefix + '-01'; } else if (type === 'next-month') { day = this.nextMonthDatePrefix + '-01'; } else { day = this.formatedToday; } if (day === this.formatedDate) return; this.pickDay(day); }, toDate: function toDate(val) { if (!val) { throw new Error('invalid val'); } return val instanceof Date ? val : new Date(val); }, rangeValidator: function rangeValidator(date, isStart) { var firstDayOfWeek = this.realFirstDayOfWeek; var expected = isStart ? firstDayOfWeek : firstDayOfWeek === 0 ? 6 : firstDayOfWeek - 1; var message = (isStart ? 'start' : 'end') + ' of range should be ' + weekDays[expected] + '.'; if (date.getDay() !== expected) { console.warn('[ElementCalendar]', message, 'Invalid range will be ignored.'); return false; } return true; } }, computed: { prevMonthDatePrefix: function prevMonthDatePrefix() { var temp = new Date(this.date.getTime()); temp.setDate(0); return date_default.a.format(temp, 'yyyy-MM'); }, curMonthDatePrefix: function curMonthDatePrefix() { return date_default.a.format(this.date, 'yyyy-MM'); }, nextMonthDatePrefix: function nextMonthDatePrefix() { var temp = new Date(this.date.getFullYear(), this.date.getMonth() + 1, 1); return date_default.a.format(temp, 'yyyy-MM'); }, formatedDate: function formatedDate() { return date_default.a.format(this.date, 'yyyy-MM-dd'); }, i18nDate: function i18nDate() { var year = this.date.getFullYear(); var month = this.date.getMonth() + 1; return year + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + month); }, formatedToday: function formatedToday() { return date_default.a.format(this.now, 'yyyy-MM-dd'); }, realSelectedDay: { get: function get() { if (!this.value) return this.selectedDay; return this.formatedDate; }, set: function set(val) { this.selectedDay = val; var date = new Date(val); this.$emit('input', date); } }, date: function date() { if (!this.value) { if (this.realSelectedDay) { var d = this.selectedDay.split('-'); return new Date(d[0], d[1] - 1, d[2]); } else if (this.validatedRange.length) { return this.validatedRange[0][0]; } return this.now; } else { return this.toDate(this.value); } }, // if range is valid, we get a two-digit array validatedRange: function validatedRange() { var _this = this; var range = this.range; if (!range) return []; range = range.reduce(function (prev, val, index) { var date = _this.toDate(val); if (_this.rangeValidator(date, index === 0)) { prev = prev.concat(date); } return prev; }, []); if (range.length === 2) { var _range = range, start = _range[0], end = _range[1]; if (start > end) { console.warn('[ElementCalendar]end time should be greater than start time'); return []; } // start time and end time in one month if (Object(date_util_["validateRangeInOneMonth"])(start, end)) { return [[start, end]]; } var data = []; var startDay = new Date(start.getFullYear(), start.getMonth() + 1, 1); var lastDay = this.toDate(startDay.getTime() - oneDay); if (!Object(date_util_["validateRangeInOneMonth"])(startDay, end)) { console.warn('[ElementCalendar]start time and end time interval must not exceed two months'); return []; } // 第一个月的时间范围 data.push([start, lastDay]); // 下一月的时间范围,需要计算一下该月的第一个周起始日 var firstDayOfWeek = this.realFirstDayOfWeek; var nextMontFirstDay = startDay.getDay(); var interval = 0; if (nextMontFirstDay !== firstDayOfWeek) { if (firstDayOfWeek === 0) { interval = 7 - nextMontFirstDay; } else { interval = firstDayOfWeek - nextMontFirstDay; interval = interval > 0 ? interval : 7 + interval; } } startDay = this.toDate(startDay.getTime() + interval * oneDay); if (startDay.getDate() < end.getDate()) { data.push([startDay, end]); } return data; } return []; }, realFirstDayOfWeek: function realFirstDayOfWeek() { if (this.firstDayOfWeek < 1 || this.firstDayOfWeek > 6) { return 0; } return Math.floor(this.firstDayOfWeek); } }, data: function data() { return { selectedDay: '', now: new Date() }; } }); // CONCATENATED MODULE: ./packages/calendar/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_calendar_src_mainvue_type_script_lang_js_ = (calendar_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/calendar/src/main.vue /* normalize component */ var calendar_src_main_component = normalizeComponent( packages_calendar_src_mainvue_type_script_lang_js_, mainvue_type_template_id_6d9756be_render, mainvue_type_template_id_6d9756be_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var calendar_src_main_api; } calendar_src_main_component.options.__file = "packages/calendar/src/main.vue" /* harmony default export */ var calendar_src_main = (calendar_src_main_component.exports); // CONCATENATED MODULE: ./packages/calendar/index.js /* istanbul ignore next */ calendar_src_main.install = function (Vue) { Vue.component(calendar_src_main.name, calendar_src_main); }; /* harmony default export */ var calendar = (calendar_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/backtop/src/main.vue?vue&type=template&id=257dd4a9& var mainvue_type_template_id_257dd4a9_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("transition", { attrs: { name: "el-fade-in" } }, [ _vm.visible ? _c( "div", { staticClass: "el-backtop", style: { right: _vm.styleRight, bottom: _vm.styleBottom }, on: { click: function($event) { $event.stopPropagation() return _vm.handleClick($event) } } }, [ _vm._t("default", [_c("el-icon", { attrs: { name: "caret-top" } })]) ], 2 ) : _vm._e() ]) } var mainvue_type_template_id_257dd4a9_staticRenderFns = [] mainvue_type_template_id_257dd4a9_render._withStripped = true // CONCATENATED MODULE: ./packages/backtop/src/main.vue?vue&type=template&id=257dd4a9& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/backtop/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // var cubic = function cubic(value) { return Math.pow(value, 3); }; var easeInOutCubic = function easeInOutCubic(value) { return value < 0.5 ? cubic(value * 2) / 2 : 1 - cubic((1 - value) * 2) / 2; }; /* harmony default export */ var backtop_src_mainvue_type_script_lang_js_ = ({ name: 'ElBacktop', props: { visibilityHeight: { type: Number, default: 200 }, target: [String], right: { type: Number, default: 40 }, bottom: { type: Number, default: 40 } }, data: function data() { return { el: null, container: null, visible: false }; }, computed: { styleBottom: function styleBottom() { return this.bottom + 'px'; }, styleRight: function styleRight() { return this.right + 'px'; } }, mounted: function mounted() { this.init(); this.throttledScrollHandler = throttle_default()(300, this.onScroll); this.container.addEventListener('scroll', this.throttledScrollHandler); }, methods: { init: function init() { this.container = document; this.el = document.documentElement; if (this.target) { this.el = document.querySelector(this.target); if (!this.el) { throw new Error('target is not existed: ' + this.target); } this.container = this.el; } }, onScroll: function onScroll() { var scrollTop = this.el.scrollTop; this.visible = scrollTop >= this.visibilityHeight; }, handleClick: function handleClick(e) { this.scrollToTop(); this.$emit('click', e); }, scrollToTop: function scrollToTop() { var el = this.el; var beginTime = Date.now(); var beginValue = el.scrollTop; var rAF = window.requestAnimationFrame || function (func) { return setTimeout(func, 16); }; var frameFunc = function frameFunc() { var progress = (Date.now() - beginTime) / 500; if (progress < 1) { el.scrollTop = beginValue * (1 - easeInOutCubic(progress)); rAF(frameFunc); } else { el.scrollTop = 0; } }; rAF(frameFunc); } }, beforeDestroy: function beforeDestroy() { this.container.removeEventListener('scroll', this.throttledScrollHandler); } }); // CONCATENATED MODULE: ./packages/backtop/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_backtop_src_mainvue_type_script_lang_js_ = (backtop_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/backtop/src/main.vue /* normalize component */ var backtop_src_main_component = normalizeComponent( packages_backtop_src_mainvue_type_script_lang_js_, mainvue_type_template_id_257dd4a9_render, mainvue_type_template_id_257dd4a9_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var backtop_src_main_api; } backtop_src_main_component.options.__file = "packages/backtop/src/main.vue" /* harmony default export */ var backtop_src_main = (backtop_src_main_component.exports); // CONCATENATED MODULE: ./packages/backtop/index.js /* istanbul ignore next */ backtop_src_main.install = function (Vue) { Vue.component(backtop_src_main.name, backtop_src_main); }; /* harmony default export */ var backtop = (backtop_src_main); // CONCATENATED MODULE: ./packages/infinite-scroll/src/main.js var getStyleComputedProperty = function getStyleComputedProperty(element, property) { if (element === window) { element = document.documentElement; } if (element.nodeType !== 1) { return []; } // NOTE: 1 DOM access here var css = window.getComputedStyle(element, null); return property ? css[property] : css; }; var entries = function entries(obj) { return Object.keys(obj || {}).map(function (key) { return [key, obj[key]]; }); }; var getPositionSize = function getPositionSize(el, prop) { return el === window || el === document ? document.documentElement[prop] : el[prop]; }; var getOffsetHeight = function getOffsetHeight(el) { return getPositionSize(el, 'offsetHeight'); }; var getClientHeight = function getClientHeight(el) { return getPositionSize(el, 'clientHeight'); }; var scope = 'ElInfiniteScroll'; var attributes = { delay: { type: Number, default: 200 }, distance: { type: Number, default: 0 }, disabled: { type: Boolean, default: false }, immediate: { type: Boolean, default: true } }; var main_getScrollOptions = function getScrollOptions(el, vm) { if (!Object(types_["isHtmlElement"])(el)) return {}; return entries(attributes).reduce(function (map, _ref) { var key = _ref[0], option = _ref[1]; var type = option.type, defaultValue = option.default; var value = el.getAttribute('infinite-scroll-' + key); value = Object(types_["isUndefined"])(vm[value]) ? value : vm[value]; switch (type) { case Number: value = Number(value); value = Number.isNaN(value) ? defaultValue : value; break; case Boolean: value = Object(types_["isDefined"])(value) ? value === 'false' ? false : Boolean(value) : defaultValue; break; default: value = type(value); } map[key] = value; return map; }, {}); }; var getElementTop = function getElementTop(el) { return el.getBoundingClientRect().top; }; var main_handleScroll = function handleScroll(cb) { var _scope = this[scope], el = _scope.el, vm = _scope.vm, container = _scope.container, observer = _scope.observer; var _getScrollOptions = main_getScrollOptions(el, vm), distance = _getScrollOptions.distance, disabled = _getScrollOptions.disabled; if (disabled) return; var containerInfo = container.getBoundingClientRect(); if (!containerInfo.width && !containerInfo.height) return; var shouldTrigger = false; if (container === el) { // be aware of difference between clientHeight & offsetHeight & window.getComputedStyle().height var scrollBottom = container.scrollTop + getClientHeight(container); shouldTrigger = container.scrollHeight - scrollBottom <= distance; } else { var heightBelowTop = getOffsetHeight(el) + getElementTop(el) - getElementTop(container); var offsetHeight = getOffsetHeight(container); var borderBottom = Number.parseFloat(getStyleComputedProperty(container, 'borderBottomWidth')); shouldTrigger = heightBelowTop - offsetHeight + borderBottom <= distance; } if (shouldTrigger && Object(types_["isFunction"])(cb)) { cb.call(vm); } else if (observer) { observer.disconnect(); this[scope].observer = null; } }; /* harmony default export */ var infinite_scroll_src_main = ({ name: 'InfiniteScroll', inserted: function inserted(el, binding, vnode) { var cb = binding.value; var vm = vnode.context; // only include vertical scroll var container = Object(dom_["getScrollContainer"])(el, true); var _getScrollOptions2 = main_getScrollOptions(el, vm), delay = _getScrollOptions2.delay, immediate = _getScrollOptions2.immediate; var onScroll = debounce_default()(delay, main_handleScroll.bind(el, cb)); el[scope] = { el: el, vm: vm, container: container, onScroll: onScroll }; if (container) { container.addEventListener('scroll', onScroll); if (immediate) { var observer = el[scope].observer = new MutationObserver(onScroll); observer.observe(container, { childList: true, subtree: true }); onScroll(); } } }, unbind: function unbind(el) { var _el$scope = el[scope], container = _el$scope.container, onScroll = _el$scope.onScroll; if (container) { container.removeEventListener('scroll', onScroll); } } }); // CONCATENATED MODULE: ./packages/infinite-scroll/index.js /* istanbul ignore next */ infinite_scroll_src_main.install = function (Vue) { Vue.directive(infinite_scroll_src_main.name, infinite_scroll_src_main); }; /* harmony default export */ var infinite_scroll = (infinite_scroll_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/page-header/src/main.vue?vue&type=template&id=5070954c& var mainvue_type_template_id_5070954c_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c("div", { staticClass: "el-page-header" }, [ _c( "div", { staticClass: "el-page-header__left", on: { click: function($event) { _vm.$emit("back") } } }, [ _c("i", { staticClass: "el-icon-back" }), _c( "div", { staticClass: "el-page-header__title" }, [_vm._t("title", [_vm._v(_vm._s(_vm.title))])], 2 ) ] ), _c( "div", { staticClass: "el-page-header__content" }, [_vm._t("content", [_vm._v(_vm._s(_vm.content))])], 2 ) ]) } var mainvue_type_template_id_5070954c_staticRenderFns = [] mainvue_type_template_id_5070954c_render._withStripped = true // CONCATENATED MODULE: ./packages/page-header/src/main.vue?vue&type=template&id=5070954c& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/page-header/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // /* harmony default export */ var page_header_src_mainvue_type_script_lang_js_ = ({ name: 'ElPageHeader', props: { title: { type: String, default: function _default() { return Object(lib_locale_["t"])('el.pageHeader.title'); } }, content: String } }); // CONCATENATED MODULE: ./packages/page-header/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_page_header_src_mainvue_type_script_lang_js_ = (page_header_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/page-header/src/main.vue /* normalize component */ var page_header_src_main_component = normalizeComponent( packages_page_header_src_mainvue_type_script_lang_js_, mainvue_type_template_id_5070954c_render, mainvue_type_template_id_5070954c_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var page_header_src_main_api; } page_header_src_main_component.options.__file = "packages/page-header/src/main.vue" /* harmony default export */ var page_header_src_main = (page_header_src_main_component.exports); // CONCATENATED MODULE: ./packages/page-header/index.js /* istanbul ignore next */ page_header_src_main.install = function (Vue) { Vue.component(page_header_src_main.name, page_header_src_main); }; /* harmony default export */ var page_header = (page_header_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-panel.vue?vue&type=template&id=34932346& var cascader_panelvue_type_template_id_34932346_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "div", { class: ["el-cascader-panel", _vm.border && "is-bordered"], on: { keydown: _vm.handleKeyDown } }, _vm._l(_vm.menus, function(menu, index) { return _c("cascader-menu", { key: index, ref: "menu", refInFor: true, attrs: { index: index, nodes: menu } }) }), 1 ) } var cascader_panelvue_type_template_id_34932346_staticRenderFns = [] cascader_panelvue_type_template_id_34932346_render._withStripped = true // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue?vue&type=template&id=34932346& // EXTERNAL MODULE: external "element-ui/lib/radio" var radio_ = __webpack_require__(43); var radio_default = /*#__PURE__*/__webpack_require__.n(radio_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-node.vue?vue&type=script&lang=js& var stopPropagation = function stopPropagation(e) { return e.stopPropagation(); }; /* harmony default export */ var cascader_nodevue_type_script_lang_js_ = ({ inject: ['panel'], components: { ElCheckbox: checkbox_default.a, ElRadio: radio_default.a }, props: { node: { required: true }, nodeId: String }, computed: { config: function config() { return this.panel.config; }, isLeaf: function isLeaf() { return this.node.isLeaf; }, isDisabled: function isDisabled() { return this.node.isDisabled; }, checkedValue: function checkedValue() { return this.panel.checkedValue; }, isChecked: function isChecked() { return this.node.isSameNode(this.checkedValue); }, inActivePath: function inActivePath() { return this.isInPath(this.panel.activePath); }, inCheckedPath: function inCheckedPath() { var _this = this; if (!this.config.checkStrictly) return false; return this.panel.checkedNodePaths.some(function (checkedPath) { return _this.isInPath(checkedPath); }); }, value: function value() { return this.node.getValueByOption(); } }, methods: { handleExpand: function handleExpand() { var _this2 = this; var panel = this.panel, node = this.node, isDisabled = this.isDisabled, config = this.config; var multiple = config.multiple, checkStrictly = config.checkStrictly; if (!checkStrictly && isDisabled || node.loading) return; if (config.lazy && !node.loaded) { panel.lazyLoad(node, function () { // do not use cached leaf value here, invoke this.isLeaf to get new value. var isLeaf = _this2.isLeaf; if (!isLeaf) _this2.handleExpand(); if (multiple) { // if leaf sync checked state, else clear checked state var checked = isLeaf ? node.checked : false; _this2.handleMultiCheckChange(checked); } }); } else { panel.handleExpand(node); } }, handleCheckChange: function handleCheckChange() { var panel = this.panel, value = this.value, node = this.node; panel.handleCheckChange(value); panel.handleExpand(node); }, handleMultiCheckChange: function handleMultiCheckChange(checked) { this.node.doCheck(checked); this.panel.calculateMultiCheckedValue(); }, isInPath: function isInPath(pathNodes) { var node = this.node; var selectedPathNode = pathNodes[node.level - 1] || {}; return selectedPathNode.uid === node.uid; }, renderPrefix: function renderPrefix(h) { var isLeaf = this.isLeaf, isChecked = this.isChecked, config = this.config; var checkStrictly = config.checkStrictly, multiple = config.multiple; if (multiple) { return this.renderCheckbox(h); } else if (checkStrictly) { return this.renderRadio(h); } else if (isLeaf && isChecked) { return this.renderCheckIcon(h); } return null; }, renderPostfix: function renderPostfix(h) { var node = this.node, isLeaf = this.isLeaf; if (node.loading) { return this.renderLoadingIcon(h); } else if (!isLeaf) { return this.renderExpandIcon(h); } return null; }, renderCheckbox: function renderCheckbox(h) { var node = this.node, config = this.config, isDisabled = this.isDisabled; var events = { on: { change: this.handleMultiCheckChange }, nativeOn: {} }; if (config.checkStrictly) { // when every node is selectable, click event should not trigger expand event. events.nativeOn.click = stopPropagation; } return h('el-checkbox', external_babel_helper_vue_jsx_merge_props_default()([{ attrs: { value: node.checked, indeterminate: node.indeterminate, disabled: isDisabled } }, events])); }, renderRadio: function renderRadio(h) { var checkedValue = this.checkedValue, value = this.value, isDisabled = this.isDisabled; // to keep same reference if value cause radio's checked state is calculated by reference comparision; if (Object(util_["isEqual"])(value, checkedValue)) { value = checkedValue; } return h( 'el-radio', { attrs: { value: checkedValue, label: value, disabled: isDisabled }, on: { 'change': this.handleCheckChange }, nativeOn: { 'click': stopPropagation } }, [h('span')] ); }, renderCheckIcon: function renderCheckIcon(h) { return h('i', { 'class': 'el-icon-check el-cascader-node__prefix' }); }, renderLoadingIcon: function renderLoadingIcon(h) { return h('i', { 'class': 'el-icon-loading el-cascader-node__postfix' }); }, renderExpandIcon: function renderExpandIcon(h) { return h('i', { 'class': 'el-icon-arrow-right el-cascader-node__postfix' }); }, renderContent: function renderContent(h) { var panel = this.panel, node = this.node; var render = panel.renderLabelFn; var vnode = render ? render({ node: node, data: node.data }) : null; return h( 'span', { 'class': 'el-cascader-node__label' }, [vnode || node.label] ); } }, render: function render(h) { var _this3 = this; var inActivePath = this.inActivePath, inCheckedPath = this.inCheckedPath, isChecked = this.isChecked, isLeaf = this.isLeaf, isDisabled = this.isDisabled, config = this.config, nodeId = this.nodeId; var expandTrigger = config.expandTrigger, checkStrictly = config.checkStrictly, multiple = config.multiple; var disabled = !checkStrictly && isDisabled; var events = { on: {} }; if (expandTrigger === 'click') { events.on.click = this.handleExpand; } else { events.on.mouseenter = function (e) { _this3.handleExpand(); _this3.$emit('expand', e); }; events.on.focus = function (e) { _this3.handleExpand(); _this3.$emit('expand', e); }; } if (isLeaf && !isDisabled && !checkStrictly && !multiple) { events.on.click = this.handleCheckChange; } return h( 'li', external_babel_helper_vue_jsx_merge_props_default()([{ attrs: { role: 'menuitem', id: nodeId, 'aria-expanded': inActivePath, tabindex: disabled ? null : -1 }, 'class': { 'el-cascader-node': true, 'is-selectable': checkStrictly, 'in-active-path': inActivePath, 'in-checked-path': inCheckedPath, 'is-active': isChecked, 'is-disabled': disabled } }, events]), [this.renderPrefix(h), this.renderContent(h), this.renderPostfix(h)] ); } }); // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-node.vue?vue&type=script&lang=js& /* harmony default export */ var src_cascader_nodevue_type_script_lang_js_ = (cascader_nodevue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-node.vue var cascader_node_render, cascader_node_staticRenderFns /* normalize component */ var cascader_node_component = normalizeComponent( src_cascader_nodevue_type_script_lang_js_, cascader_node_render, cascader_node_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var cascader_node_api; } cascader_node_component.options.__file = "packages/cascader-panel/src/cascader-node.vue" /* harmony default export */ var cascader_node = (cascader_node_component.exports); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-menu.vue?vue&type=script&lang=js& /* harmony default export */ var cascader_menuvue_type_script_lang_js_ = ({ name: 'ElCascaderMenu', mixins: [locale_default.a], inject: ['panel'], components: { ElScrollbar: scrollbar_default.a, CascaderNode: cascader_node }, props: { nodes: { type: Array, required: true }, index: Number }, data: function data() { return { activeNode: null, hoverTimer: null, id: Object(util_["generateId"])() }; }, computed: { isEmpty: function isEmpty() { return !this.nodes.length; }, menuId: function menuId() { return 'cascader-menu-' + this.id + '-' + this.index; } }, methods: { handleExpand: function handleExpand(e) { this.activeNode = e.target; }, handleMouseMove: function handleMouseMove(e) { var activeNode = this.activeNode, hoverTimer = this.hoverTimer; var hoverZone = this.$refs.hoverZone; if (!activeNode || !hoverZone) return; if (activeNode.contains(e.target)) { clearTimeout(hoverTimer); var _$el$getBoundingClien = this.$el.getBoundingClientRect(), left = _$el$getBoundingClien.left; var startX = e.clientX - left; var _$el = this.$el, offsetWidth = _$el.offsetWidth, offsetHeight = _$el.offsetHeight; var top = activeNode.offsetTop; var bottom = top + activeNode.offsetHeight; hoverZone.innerHTML = '\n <path style="pointer-events: auto;" fill="transparent" d="M' + startX + ' ' + top + ' L' + offsetWidth + ' 0 V' + top + ' Z" />\n <path style="pointer-events: auto;" fill="transparent" d="M' + startX + ' ' + bottom + ' L' + offsetWidth + ' ' + offsetHeight + ' V' + bottom + ' Z" />\n '; } else if (!hoverTimer) { this.hoverTimer = setTimeout(this.clearHoverZone, this.panel.config.hoverThreshold); } }, clearHoverZone: function clearHoverZone() { var hoverZone = this.$refs.hoverZone; if (!hoverZone) return; hoverZone.innerHTML = ''; }, renderEmptyText: function renderEmptyText(h) { return h( 'div', { 'class': 'el-cascader-menu__empty-text' }, [this.t('el.cascader.noData')] ); }, renderNodeList: function renderNodeList(h) { var menuId = this.menuId; var isHoverMenu = this.panel.isHoverMenu; var events = { on: {} }; if (isHoverMenu) { events.on.expand = this.handleExpand; } var nodes = this.nodes.map(function (node, index) { var hasChildren = node.hasChildren; return h('cascader-node', external_babel_helper_vue_jsx_merge_props_default()([{ key: node.uid, attrs: { node: node, 'node-id': menuId + '-' + index, 'aria-haspopup': hasChildren, 'aria-owns': hasChildren ? menuId : null } }, events])); }); return [].concat(nodes, [isHoverMenu ? h('svg', { ref: 'hoverZone', 'class': 'el-cascader-menu__hover-zone' }) : null]); } }, render: function render(h) { var isEmpty = this.isEmpty, menuId = this.menuId; var events = { nativeOn: {} }; // optimize hover to expand experience (#8010) if (this.panel.isHoverMenu) { events.nativeOn.mousemove = this.handleMouseMove; // events.nativeOn.mouseleave = this.clearHoverZone; } return h( 'el-scrollbar', external_babel_helper_vue_jsx_merge_props_default()([{ attrs: { tag: 'ul', role: 'menu', id: menuId, 'wrap-class': 'el-cascader-menu__wrap', 'view-class': { 'el-cascader-menu__list': true, 'is-empty': isEmpty } }, 'class': 'el-cascader-menu' }, events]), [isEmpty ? this.renderEmptyText(h) : this.renderNodeList(h)] ); } }); // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-menu.vue?vue&type=script&lang=js& /* harmony default export */ var src_cascader_menuvue_type_script_lang_js_ = (cascader_menuvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-menu.vue var cascader_menu_render, cascader_menu_staticRenderFns /* normalize component */ var cascader_menu_component = normalizeComponent( src_cascader_menuvue_type_script_lang_js_, cascader_menu_render, cascader_menu_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var cascader_menu_api; } cascader_menu_component.options.__file = "packages/cascader-panel/src/cascader-menu.vue" /* harmony default export */ var cascader_menu = (cascader_menu_component.exports); // CONCATENATED MODULE: ./packages/cascader-panel/src/node.js var node_createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); function src_node_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var uid = 0; var src_node_Node = function () { function Node(data, config, parentNode) { src_node_classCallCheck(this, Node); this.data = data; this.config = config; this.parent = parentNode || null; this.level = !this.parent ? 1 : this.parent.level + 1; this.uid = uid++; this.initState(); this.initChildren(); } Node.prototype.initState = function initState() { var _config = this.config, valueKey = _config.value, labelKey = _config.label; this.value = this.data[valueKey]; this.label = this.data[labelKey]; this.pathNodes = this.calculatePathNodes(); this.path = this.pathNodes.map(function (node) { return node.value; }); this.pathLabels = this.pathNodes.map(function (node) { return node.label; }); // lazy load this.loading = false; this.loaded = false; }; Node.prototype.initChildren = function initChildren() { var _this = this; var config = this.config; var childrenKey = config.children; var childrenData = this.data[childrenKey]; this.hasChildren = Array.isArray(childrenData); this.children = (childrenData || []).map(function (child) { return new Node(child, config, _this); }); }; Node.prototype.calculatePathNodes = function calculatePathNodes() { var nodes = [this]; var parent = this.parent; while (parent) { nodes.unshift(parent); parent = parent.parent; } return nodes; }; Node.prototype.getPath = function getPath() { return this.path; }; Node.prototype.getValue = function getValue() { return this.value; }; Node.prototype.getValueByOption = function getValueByOption() { return this.config.emitPath ? this.getPath() : this.getValue(); }; Node.prototype.getText = function getText(allLevels, separator) { return allLevels ? this.pathLabels.join(separator) : this.label; }; Node.prototype.isSameNode = function isSameNode(checkedValue) { var value = this.getValueByOption(); return this.config.multiple && Array.isArray(checkedValue) ? checkedValue.some(function (val) { return Object(util_["isEqual"])(val, value); }) : Object(util_["isEqual"])(checkedValue, value); }; Node.prototype.broadcast = function broadcast(event) { for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { args[_key - 1] = arguments[_key]; } var handlerName = 'onParent' + Object(util_["capitalize"])(event); this.children.forEach(function (child) { if (child) { // bottom up child.broadcast.apply(child, [event].concat(args)); child[handlerName] && child[handlerName].apply(child, args); } }); }; Node.prototype.emit = function emit(event) { var parent = this.parent; var handlerName = 'onChild' + Object(util_["capitalize"])(event); if (parent) { for (var _len2 = arguments.length, args = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { args[_key2 - 1] = arguments[_key2]; } parent[handlerName] && parent[handlerName].apply(parent, args); parent.emit.apply(parent, [event].concat(args)); } }; Node.prototype.onParentCheck = function onParentCheck(checked) { if (!this.isDisabled) { this.setCheckState(checked); } }; Node.prototype.onChildCheck = function onChildCheck() { var children = this.children; var validChildren = children.filter(function (child) { return !child.isDisabled; }); var checked = validChildren.length ? validChildren.every(function (child) { return child.checked; }) : false; this.setCheckState(checked); }; Node.prototype.setCheckState = function setCheckState(checked) { var totalNum = this.children.length; var checkedNum = this.children.reduce(function (c, p) { var num = p.checked ? 1 : p.indeterminate ? 0.5 : 0; return c + num; }, 0); this.checked = checked; this.indeterminate = checkedNum !== totalNum && checkedNum > 0; }; Node.prototype.syncCheckState = function syncCheckState(checkedValue) { var value = this.getValueByOption(); var checked = this.isSameNode(checkedValue, value); this.doCheck(checked); }; Node.prototype.doCheck = function doCheck(checked) { if (this.checked !== checked) { if (this.config.checkStrictly) { this.checked = checked; } else { // bottom up to unify the calculation of the indeterminate state this.broadcast('check', checked); this.setCheckState(checked); this.emit('check'); } } }; node_createClass(Node, [{ key: 'isDisabled', get: function get() { var data = this.data, parent = this.parent, config = this.config; var disabledKey = config.disabled; var checkStrictly = config.checkStrictly; return data[disabledKey] || !checkStrictly && parent && parent.isDisabled; } }, { key: 'isLeaf', get: function get() { var data = this.data, loaded = this.loaded, hasChildren = this.hasChildren, children = this.children; var _config2 = this.config, lazy = _config2.lazy, leafKey = _config2.leaf; if (lazy) { var isLeaf = Object(shared_["isDef"])(data[leafKey]) ? data[leafKey] : loaded ? !children.length : false; this.hasChildren = !isLeaf; return isLeaf; } return !hasChildren; } }]); return Node; }(); /* harmony default export */ var src_node = (src_node_Node); // CONCATENATED MODULE: ./packages/cascader-panel/src/store.js function store_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var flatNodes = function flatNodes(data, leafOnly) { return data.reduce(function (res, node) { if (node.isLeaf) { res.push(node); } else { !leafOnly && res.push(node); res = res.concat(flatNodes(node.children, leafOnly)); } return res; }, []); }; var store_Store = function () { function Store(data, config) { store_classCallCheck(this, Store); this.config = config; this.initNodes(data); } Store.prototype.initNodes = function initNodes(data) { var _this = this; data = Object(util_["coerceTruthyValueToArray"])(data); this.nodes = data.map(function (nodeData) { return new src_node(nodeData, _this.config); }); this.flattedNodes = this.getFlattedNodes(false, false); this.leafNodes = this.getFlattedNodes(true, false); }; Store.prototype.appendNode = function appendNode(nodeData, parentNode) { var node = new src_node(nodeData, this.config, parentNode); var children = parentNode ? parentNode.children : this.nodes; children.push(node); }; Store.prototype.appendNodes = function appendNodes(nodeDataList, parentNode) { var _this2 = this; nodeDataList = Object(util_["coerceTruthyValueToArray"])(nodeDataList); nodeDataList.forEach(function (nodeData) { return _this2.appendNode(nodeData, parentNode); }); }; Store.prototype.getNodes = function getNodes() { return this.nodes; }; Store.prototype.getFlattedNodes = function getFlattedNodes(leafOnly) { var cached = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; var cachedNodes = leafOnly ? this.leafNodes : this.flattedNodes; return cached ? cachedNodes : flatNodes(this.nodes, leafOnly); }; Store.prototype.getNodeByValue = function getNodeByValue(value) { if (value) { var nodes = this.getFlattedNodes(false, !this.config.lazy).filter(function (node) { return Object(util_["valueEquals"])(node.path, value) || node.value === value; }); return nodes && nodes.length ? nodes[0] : null; } return null; }; return Store; }(); /* harmony default export */ var cascader_panel_src_store = (store_Store); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/cascader-panel/src/cascader-panel.vue?vue&type=script&lang=js& var cascader_panelvue_type_script_lang_js_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; // // // // // // // // // // // // // // // // var cascader_panelvue_type_script_lang_js_KeyCode = aria_utils_default.a.keys; var DefaultProps = { expandTrigger: 'click', // or hover multiple: false, checkStrictly: false, // whether all nodes can be selected emitPath: true, // wether to emit an array of all levels value in which node is located lazy: false, lazyLoad: util_["noop"], value: 'value', label: 'label', children: 'children', leaf: 'leaf', disabled: 'disabled', hoverThreshold: 500 }; var cascader_panelvue_type_script_lang_js_isLeaf = function isLeaf(el) { return !el.getAttribute('aria-owns'); }; var getSibling = function getSibling(el, distance) { var parentNode = el.parentNode; if (parentNode) { var siblings = parentNode.querySelectorAll('.el-cascader-node[tabindex="-1"]'); var index = Array.prototype.indexOf.call(siblings, el); return siblings[index + distance] || null; } return null; }; var getMenuIndex = function getMenuIndex(el, distance) { if (!el) return; var pieces = el.id.split('-'); return Number(pieces[pieces.length - 2]); }; var focusNode = function focusNode(el) { if (!el) return; el.focus(); !cascader_panelvue_type_script_lang_js_isLeaf(el) && el.click(); }; var checkNode = function checkNode(el) { if (!el) return; var input = el.querySelector('input'); if (input) { input.click(); } else if (cascader_panelvue_type_script_lang_js_isLeaf(el)) { el.click(); } }; /* harmony default export */ var cascader_panelvue_type_script_lang_js_ = ({ name: 'ElCascaderPanel', components: { CascaderMenu: cascader_menu }, props: { value: {}, options: Array, props: Object, border: { type: Boolean, default: true }, renderLabel: Function }, provide: function provide() { return { panel: this }; }, data: function data() { return { checkedValue: null, checkedNodePaths: [], store: [], menus: [], activePath: [], loadCount: 0 }; }, computed: { config: function config() { return merge_default()(cascader_panelvue_type_script_lang_js_extends({}, DefaultProps), this.props || {}); }, multiple: function multiple() { return this.config.multiple; }, checkStrictly: function checkStrictly() { return this.config.checkStrictly; }, leafOnly: function leafOnly() { return !this.checkStrictly; }, isHoverMenu: function isHoverMenu() { return this.config.expandTrigger === 'hover'; }, renderLabelFn: function renderLabelFn() { return this.renderLabel || this.$scopedSlots.default; } }, watch: { options: { handler: function handler() { this.initStore(); }, immediate: true, deep: true }, value: function value() { this.syncCheckedValue(); this.checkStrictly && this.calculateCheckedNodePaths(); }, checkedValue: function checkedValue(val) { if (!Object(util_["isEqual"])(val, this.value)) { this.checkStrictly && this.calculateCheckedNodePaths(); this.$emit('input', val); this.$emit('change', val); } } }, mounted: function mounted() { if (!Object(util_["isEmpty"])(this.value)) { this.syncCheckedValue(); } }, methods: { initStore: function initStore() { var config = this.config, options = this.options; if (config.lazy && Object(util_["isEmpty"])(options)) { this.lazyLoad(); } else { this.store = new cascader_panel_src_store(options, config); this.menus = [this.store.getNodes()]; this.syncMenuState(); } }, syncCheckedValue: function syncCheckedValue() { var value = this.value, checkedValue = this.checkedValue; if (!Object(util_["isEqual"])(value, checkedValue)) { this.checkedValue = value; this.syncMenuState(); } }, syncMenuState: function syncMenuState() { var multiple = this.multiple, checkStrictly = this.checkStrictly; this.syncActivePath(); multiple && this.syncMultiCheckState(); checkStrictly && this.calculateCheckedNodePaths(); this.$nextTick(this.scrollIntoView); }, syncMultiCheckState: function syncMultiCheckState() { var _this = this; var nodes = this.getFlattedNodes(this.leafOnly); nodes.forEach(function (node) { node.syncCheckState(_this.checkedValue); }); }, syncActivePath: function syncActivePath() { var _this2 = this; var store = this.store, multiple = this.multiple, activePath = this.activePath, checkedValue = this.checkedValue; if (!Object(util_["isEmpty"])(activePath)) { var nodes = activePath.map(function (node) { return _this2.getNodeByValue(node.getValue()); }); this.expandNodes(nodes); } else if (!Object(util_["isEmpty"])(checkedValue)) { var value = multiple ? checkedValue[0] : checkedValue; var checkedNode = this.getNodeByValue(value) || {}; var _nodes = (checkedNode.pathNodes || []).slice(0, -1); this.expandNodes(_nodes); } else { this.activePath = []; this.menus = [store.getNodes()]; } }, expandNodes: function expandNodes(nodes) { var _this3 = this; nodes.forEach(function (node) { return _this3.handleExpand(node, true /* silent */); }); }, calculateCheckedNodePaths: function calculateCheckedNodePaths() { var _this4 = this; var checkedValue = this.checkedValue, multiple = this.multiple; var checkedValues = multiple ? Object(util_["coerceTruthyValueToArray"])(checkedValue) : [checkedValue]; this.checkedNodePaths = checkedValues.map(function (v) { var checkedNode = _this4.getNodeByValue(v); return checkedNode ? checkedNode.pathNodes : []; }); }, handleKeyDown: function handleKeyDown(e) { var target = e.target, keyCode = e.keyCode; switch (keyCode) { case cascader_panelvue_type_script_lang_js_KeyCode.up: var prev = getSibling(target, -1); focusNode(prev); break; case cascader_panelvue_type_script_lang_js_KeyCode.down: var next = getSibling(target, 1); focusNode(next); break; case cascader_panelvue_type_script_lang_js_KeyCode.left: var preMenu = this.$refs.menu[getMenuIndex(target) - 1]; if (preMenu) { var expandedNode = preMenu.$el.querySelector('.el-cascader-node[aria-expanded="true"]'); focusNode(expandedNode); } break; case cascader_panelvue_type_script_lang_js_KeyCode.right: var nextMenu = this.$refs.menu[getMenuIndex(target) + 1]; if (nextMenu) { var firstNode = nextMenu.$el.querySelector('.el-cascader-node[tabindex="-1"]'); focusNode(firstNode); } break; case cascader_panelvue_type_script_lang_js_KeyCode.enter: checkNode(target); break; case cascader_panelvue_type_script_lang_js_KeyCode.esc: case cascader_panelvue_type_script_lang_js_KeyCode.tab: this.$emit('close'); break; default: return; } }, handleExpand: function handleExpand(node, silent) { var activePath = this.activePath; var level = node.level; var path = activePath.slice(0, level - 1); var menus = this.menus.slice(0, level); if (!node.isLeaf) { path.push(node); menus.push(node.children); } this.activePath = path; this.menus = menus; if (!silent) { var pathValues = path.map(function (node) { return node.getValue(); }); var activePathValues = activePath.map(function (node) { return node.getValue(); }); if (!Object(util_["valueEquals"])(pathValues, activePathValues)) { this.$emit('active-item-change', pathValues); // Deprecated this.$emit('expand-change', pathValues); } } }, handleCheckChange: function handleCheckChange(value) { this.checkedValue = value; }, lazyLoad: function lazyLoad(node, onFullfiled) { var _this5 = this; var config = this.config; if (!node) { node = node || { root: true, level: 0 }; this.store = new cascader_panel_src_store([], config); this.menus = [this.store.getNodes()]; } node.loading = true; var resolve = function resolve(dataList) { var parent = node.root ? null : node; dataList && dataList.length && _this5.store.appendNodes(dataList, parent); node.loading = false; node.loaded = true; // dispose default value on lazy load mode if (Array.isArray(_this5.checkedValue)) { var nodeValue = _this5.checkedValue[_this5.loadCount++]; var valueKey = _this5.config.value; var leafKey = _this5.config.leaf; if (Array.isArray(dataList) && dataList.filter(function (item) { return item[valueKey] === nodeValue; }).length > 0) { var checkedNode = _this5.store.getNodeByValue(nodeValue); if (!checkedNode.data[leafKey]) { _this5.lazyLoad(checkedNode, function () { _this5.handleExpand(checkedNode); }); } if (_this5.loadCount === _this5.checkedValue.length) { _this5.$parent.computePresentText(); } } } onFullfiled && onFullfiled(dataList); }; config.lazyLoad(node, resolve); }, /** * public methods */ calculateMultiCheckedValue: function calculateMultiCheckedValue() { this.checkedValue = this.getCheckedNodes(this.leafOnly).map(function (node) { return node.getValueByOption(); }); }, scrollIntoView: function scrollIntoView() { if (this.$isServer) return; var menus = this.$refs.menu || []; menus.forEach(function (menu) { var menuElement = menu.$el; if (menuElement) { var container = menuElement.querySelector('.el-scrollbar__wrap'); var activeNode = menuElement.querySelector('.el-cascader-node.is-active') || menuElement.querySelector('.el-cascader-node.in-active-path'); scroll_into_view_default()(container, activeNode); } }); }, getNodeByValue: function getNodeByValue(val) { return this.store.getNodeByValue(val); }, getFlattedNodes: function getFlattedNodes(leafOnly) { var cached = !this.config.lazy; return this.store.getFlattedNodes(leafOnly, cached); }, getCheckedNodes: function getCheckedNodes(leafOnly) { var checkedValue = this.checkedValue, multiple = this.multiple; if (multiple) { var nodes = this.getFlattedNodes(leafOnly); return nodes.filter(function (node) { return node.checked; }); } else { return Object(util_["isEmpty"])(checkedValue) ? [] : [this.getNodeByValue(checkedValue)]; } }, clearCheckedNodes: function clearCheckedNodes() { var config = this.config, leafOnly = this.leafOnly; var multiple = config.multiple, emitPath = config.emitPath; if (multiple) { this.getCheckedNodes(leafOnly).filter(function (node) { return !node.isDisabled; }).forEach(function (node) { return node.doCheck(false); }); this.calculateMultiCheckedValue(); } else { this.checkedValue = emitPath ? [] : null; } } } }); // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue?vue&type=script&lang=js& /* harmony default export */ var src_cascader_panelvue_type_script_lang_js_ = (cascader_panelvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/cascader-panel/src/cascader-panel.vue /* normalize component */ var cascader_panel_component = normalizeComponent( src_cascader_panelvue_type_script_lang_js_, cascader_panelvue_type_template_id_34932346_render, cascader_panelvue_type_template_id_34932346_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var cascader_panel_api; } cascader_panel_component.options.__file = "packages/cascader-panel/src/cascader-panel.vue" /* harmony default export */ var cascader_panel = (cascader_panel_component.exports); // CONCATENATED MODULE: ./packages/cascader-panel/index.js /* istanbul ignore next */ cascader_panel.install = function (Vue) { Vue.component(cascader_panel.name, cascader_panel); }; /* harmony default export */ var packages_cascader_panel = (cascader_panel); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/avatar/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var avatar_src_mainvue_type_script_lang_js_ = ({ name: 'ElAvatar', props: { size: { type: [Number, String], validator: function validator(val) { if (typeof val === 'string') { return ['large', 'medium', 'small'].includes(val); } return typeof val === 'number'; } }, shape: { type: String, default: 'circle', validator: function validator(val) { return ['circle', 'square'].includes(val); } }, icon: String, src: String, alt: String, srcSet: String, error: Function, fit: { type: String, default: 'cover' } }, data: function data() { return { isImageExist: true }; }, computed: { avatarClass: function avatarClass() { var size = this.size, icon = this.icon, shape = this.shape; var classList = ['el-avatar']; if (size && typeof size === 'string') { classList.push('el-avatar--' + size); } if (icon) { classList.push('el-avatar--icon'); } if (shape) { classList.push('el-avatar--' + shape); } return classList.join(' '); } }, methods: { handleError: function handleError() { var error = this.error; var errorFlag = error ? error() : undefined; if (errorFlag !== false) { this.isImageExist = false; } }, renderAvatar: function renderAvatar() { var h = this.$createElement; var icon = this.icon, src = this.src, alt = this.alt, isImageExist = this.isImageExist, srcSet = this.srcSet, fit = this.fit; if (isImageExist && src) { return h('img', { attrs: { src: src, alt: alt, srcSet: srcSet }, on: { 'error': this.handleError }, style: { 'object-fit': fit } }); } if (icon) { return h('i', { 'class': icon }); } return this.$slots.default; } }, render: function render() { var h = arguments[0]; var avatarClass = this.avatarClass, size = this.size; var sizeStyle = typeof size === 'number' ? { height: size + 'px', width: size + 'px', lineHeight: size + 'px' } : {}; return h( 'span', { 'class': avatarClass, style: sizeStyle }, [this.renderAvatar()] ); } }); // CONCATENATED MODULE: ./packages/avatar/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_avatar_src_mainvue_type_script_lang_js_ = (avatar_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/avatar/src/main.vue var src_main_render, src_main_staticRenderFns /* normalize component */ var avatar_src_main_component = normalizeComponent( packages_avatar_src_mainvue_type_script_lang_js_, src_main_render, src_main_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var avatar_src_main_api; } avatar_src_main_component.options.__file = "packages/avatar/src/main.vue" /* harmony default export */ var avatar_src_main = (avatar_src_main_component.exports); // CONCATENATED MODULE: ./packages/avatar/index.js /* istanbul ignore next */ avatar_src_main.install = function (Vue) { Vue.component(avatar_src_main.name, avatar_src_main); }; /* harmony default export */ var avatar = (avatar_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/drawer/src/main.vue?vue&type=template&id=a4885264& var mainvue_type_template_id_a4885264_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "transition", { attrs: { name: "el-drawer-fade" }, on: { "after-enter": _vm.afterEnter, "after-leave": _vm.afterLeave } }, [ _c( "div", { directives: [ { name: "show", rawName: "v-show", value: _vm.visible, expression: "visible" } ], staticClass: "el-drawer__wrapper", attrs: { tabindex: "-1" } }, [ _c( "div", { staticClass: "el-drawer__container", class: _vm.visible && "el-drawer__open", attrs: { role: "document", tabindex: "-1" }, on: { click: function($event) { if ($event.target !== $event.currentTarget) { return null } return _vm.handleWrapperClick($event) } } }, [ _c( "div", { ref: "drawer", staticClass: "el-drawer", class: [_vm.direction, _vm.customClass], style: _vm.isHorizontal ? "width: " + _vm.size : "height: " + _vm.size, attrs: { "aria-modal": "true", "aria-labelledby": "el-drawer__title", "aria-label": _vm.title, role: "dialog", tabindex: "-1" } }, [ _vm.withHeader ? _c( "header", { staticClass: "el-drawer__header", attrs: { id: "el-drawer__title" } }, [ _vm._t("title", [ _c( "span", { attrs: { role: "heading", tabindex: "0", title: _vm.title } }, [_vm._v(_vm._s(_vm.title))] ) ]), _vm.showClose ? _c( "button", { staticClass: "el-drawer__close-btn", attrs: { "aria-label": "close " + (_vm.title || "drawer"), type: "button" }, on: { click: _vm.closeDrawer } }, [ _c("i", { staticClass: "el-dialog__close el-icon el-icon-close" }) ] ) : _vm._e() ], 2 ) : _vm._e(), _vm.rendered ? _c( "section", { staticClass: "el-drawer__body" }, [_vm._t("default")], 2 ) : _vm._e() ] ) ] ) ] ) ] ) } var mainvue_type_template_id_a4885264_staticRenderFns = [] mainvue_type_template_id_a4885264_render._withStripped = true // CONCATENATED MODULE: ./packages/drawer/src/main.vue?vue&type=template&id=a4885264& // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/drawer/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var drawer_src_mainvue_type_script_lang_js_ = ({ name: 'ElDrawer', mixins: [popup_default.a, emitter_default.a], props: { appendToBody: { type: Boolean, default: false }, beforeClose: { type: Function }, customClass: { type: String, default: '' }, closeOnPressEscape: { type: Boolean, default: true }, destroyOnClose: { type: Boolean, default: false }, modal: { type: Boolean, default: true }, direction: { type: String, default: 'rtl', validator: function validator(val) { return ['ltr', 'rtl', 'ttb', 'btt'].indexOf(val) !== -1; } }, modalAppendToBody: { type: Boolean, default: true }, showClose: { type: Boolean, default: true }, size: { type: String, default: '30%' }, title: { type: String, default: '' }, visible: { type: Boolean }, wrapperClosable: { type: Boolean, default: true }, withHeader: { type: Boolean, default: true } }, computed: { isHorizontal: function isHorizontal() { return this.direction === 'rtl' || this.direction === 'ltr'; } }, data: function data() { return { closed: false, prevActiveElement: null }; }, watch: { visible: function visible(val) { var _this = this; if (val) { this.closed = false; this.$emit('open'); if (this.appendToBody) { document.body.appendChild(this.$el); } this.prevActiveElement = document.activeElement; this.$nextTick(function () { aria_utils_default.a.focusFirstDescendant(_this.$refs.drawer); }); } else { if (!this.closed) this.$emit('close'); this.$nextTick(function () { if (_this.prevActiveElement) { _this.prevActiveElement.focus(); } }); } } }, methods: { afterEnter: function afterEnter() { this.$emit('opened'); }, afterLeave: function afterLeave() { this.$emit('closed'); }, hide: function hide(cancel) { if (cancel !== false) { this.$emit('update:visible', false); this.$emit('close'); if (this.destroyOnClose === true) { this.rendered = false; } this.closed = true; } }, handleWrapperClick: function handleWrapperClick() { if (this.wrapperClosable) { this.closeDrawer(); } }, closeDrawer: function closeDrawer() { if (typeof this.beforeClose === 'function') { this.beforeClose(this.hide); } else { this.hide(); } }, handleClose: function handleClose() { // This method here will be called by PopupManger, when the `closeOnPressEscape` was set to true // pressing `ESC` will call this method, and also close the drawer. // This method also calls `beforeClose` if there was one. this.closeDrawer(); } }, mounted: function mounted() { if (this.visible) { this.rendered = true; this.open(); } }, destroyed: function destroyed() { // if appendToBody is true, remove DOM node after destroy if (this.appendToBody && this.$el && this.$el.parentNode) { this.$el.parentNode.removeChild(this.$el); } } }); // CONCATENATED MODULE: ./packages/drawer/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_drawer_src_mainvue_type_script_lang_js_ = (drawer_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/drawer/src/main.vue /* normalize component */ var drawer_src_main_component = normalizeComponent( packages_drawer_src_mainvue_type_script_lang_js_, mainvue_type_template_id_a4885264_render, mainvue_type_template_id_a4885264_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var drawer_src_main_api; } drawer_src_main_component.options.__file = "packages/drawer/src/main.vue" /* harmony default export */ var drawer_src_main = (drawer_src_main_component.exports); // CONCATENATED MODULE: ./packages/drawer/index.js /* istanbul ignore next */ drawer_src_main.install = function (Vue) { Vue.component(drawer_src_main.name, drawer_src_main); }; /* harmony default export */ var drawer = (drawer_src_main); // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/popconfirm/src/main.vue?vue&type=template&id=048de730& var mainvue_type_template_id_048de730_render = function() { var _vm = this var _h = _vm.$createElement var _c = _vm._self._c || _h return _c( "el-popover", _vm._b( { attrs: { trigger: "click" }, model: { value: _vm.visible, callback: function($$v) { _vm.visible = $$v }, expression: "visible" } }, "el-popover", _vm.$attrs, false ), [ _c("div", { staticClass: "el-popconfirm" }, [ _c("p", { staticClass: "el-popconfirm__main" }, [ !_vm.hideIcon ? _c("i", { staticClass: "el-popconfirm__icon", class: _vm.icon, style: { color: _vm.iconColor } }) : _vm._e(), _vm._v("\n " + _vm._s(_vm.title) + "\n ") ]), _c( "div", { staticClass: "el-popconfirm__action" }, [ _c( "el-button", { attrs: { size: "mini", type: _vm.cancelButtonType }, on: { click: _vm.cancel } }, [_vm._v("\n " + _vm._s(_vm.cancelButtonText) + "\n ")] ), _c( "el-button", { attrs: { size: "mini", type: _vm.confirmButtonType }, on: { click: _vm.confirm } }, [ _vm._v( "\n " + _vm._s(_vm.confirmButtonText) + "\n " ) ] ) ], 1 ) ]), _vm._t("reference", null, { slot: "reference" }) ], 2 ) } var mainvue_type_template_id_048de730_staticRenderFns = [] mainvue_type_template_id_048de730_render._withStripped = true // CONCATENATED MODULE: ./packages/popconfirm/src/main.vue?vue&type=template&id=048de730& // EXTERNAL MODULE: external "element-ui/lib/popover" var popover_ = __webpack_require__(44); var popover_default = /*#__PURE__*/__webpack_require__.n(popover_); // CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/popconfirm/src/main.vue?vue&type=script&lang=js& // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // // /* harmony default export */ var popconfirm_src_mainvue_type_script_lang_js_ = ({ name: 'ElPopconfirm', props: { title: { type: String }, confirmButtonText: { type: String, default: Object(lib_locale_["t"])('el.popconfirm.confirmButtonText') }, cancelButtonText: { type: String, default: Object(lib_locale_["t"])('el.popconfirm.cancelButtonText') }, confirmButtonType: { type: String, default: 'primary' }, cancelButtonType: { type: String, default: 'text' }, icon: { type: String, default: 'el-icon-question' }, iconColor: { type: String, default: '#f90' }, hideIcon: { type: Boolean, default: false } }, components: { ElPopover: popover_default.a, ElButton: button_default.a }, data: function data() { return { visible: false }; }, methods: { confirm: function confirm() { this.visible = false; this.$emit('onConfirm'); }, cancel: function cancel() { this.visible = false; this.$emit('onCancel'); } } }); // CONCATENATED MODULE: ./packages/popconfirm/src/main.vue?vue&type=script&lang=js& /* harmony default export */ var packages_popconfirm_src_mainvue_type_script_lang_js_ = (popconfirm_src_mainvue_type_script_lang_js_); // CONCATENATED MODULE: ./packages/popconfirm/src/main.vue /* normalize component */ var popconfirm_src_main_component = normalizeComponent( packages_popconfirm_src_mainvue_type_script_lang_js_, mainvue_type_template_id_048de730_render, mainvue_type_template_id_048de730_staticRenderFns, false, null, null, null ) /* hot reload */ if (false) { var popconfirm_src_main_api; } popconfirm_src_main_component.options.__file = "packages/popconfirm/src/main.vue" /* harmony default export */ var popconfirm_src_main = (popconfirm_src_main_component.exports); // CONCATENATED MODULE: ./packages/popconfirm/index.js /* istanbul ignore next */ popconfirm_src_main.install = function (Vue) { Vue.component(popconfirm_src_main.name, popconfirm_src_main); }; /* harmony default export */ var popconfirm = (popconfirm_src_main); // CONCATENATED MODULE: ./src/index.js /* Automatically generated by './build/bin/build-entry.js' */ var components = [packages_pagination, dialog, packages_autocomplete, packages_dropdown, packages_dropdown_menu, packages_dropdown_item, packages_menu, packages_submenu, packages_menu_item, packages_menu_item_group, packages_input, packages_input_number, packages_radio, packages_radio_group, packages_radio_button, packages_checkbox, packages_checkbox_button, packages_checkbox_group, packages_switch, packages_select, packages_option, packages_option_group, packages_button, packages_button_group, packages_table, packages_table_column, packages_date_picker, packages_time_select, packages_time_picker, popover, packages_tooltip, packages_breadcrumb, packages_breadcrumb_item, packages_form, packages_form_item, packages_tabs, packages_tab_pane, packages_tag, packages_tree, packages_alert, slider, packages_icon, packages_row, packages_col, packages_upload, packages_progress, packages_spinner, badge, card, rate, packages_steps, packages_step, carousel, scrollbar, carousel_item, packages_collapse, packages_collapse_item, packages_cascader, color_picker, transfer, packages_container, header, aside, packages_main, footer, timeline, timeline_item, packages_link, divider, packages_image, calendar, backtop, page_header, packages_cascader_panel, avatar, drawer, popconfirm, collapse_transition_default.a]; var src_install = function install(Vue) { var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; lib_locale_default.a.use(opts.locale); lib_locale_default.a.i18n(opts.i18n); components.forEach(function (component) { Vue.component(component.name, component); }); Vue.use(infinite_scroll); Vue.use(packages_loading.directive); Vue.prototype.$ELEMENT = { size: opts.size || '', zIndex: opts.zIndex || 2000 }; Vue.prototype.$loading = packages_loading.service; Vue.prototype.$msgbox = message_box; Vue.prototype.$alert = message_box.alert; Vue.prototype.$confirm = message_box.confirm; Vue.prototype.$prompt = message_box.prompt; Vue.prototype.$notify = notification; Vue.prototype.$message = packages_message; }; /* istanbul ignore if */ if (typeof window !== 'undefined' && window.Vue) { src_install(window.Vue); } /* harmony default export */ var src_0 = __webpack_exports__["default"] = ({ version: '2.13.2', locale: lib_locale_default.a.use, i18n: lib_locale_default.a.i18n, install: src_install, CollapseTransition: collapse_transition_default.a, Loading: packages_loading, Pagination: packages_pagination, Dialog: dialog, Autocomplete: packages_autocomplete, Dropdown: packages_dropdown, DropdownMenu: packages_dropdown_menu, DropdownItem: packages_dropdown_item, Menu: packages_menu, Submenu: packages_submenu, MenuItem: packages_menu_item, MenuItemGroup: packages_menu_item_group, Input: packages_input, InputNumber: packages_input_number, Radio: packages_radio, RadioGroup: packages_radio_group, RadioButton: packages_radio_button, Checkbox: packages_checkbox, CheckboxButton: packages_checkbox_button, CheckboxGroup: packages_checkbox_group, Switch: packages_switch, Select: packages_select, Option: packages_option, OptionGroup: packages_option_group, Button: packages_button, ButtonGroup: packages_button_group, Table: packages_table, TableColumn: packages_table_column, DatePicker: packages_date_picker, TimeSelect: packages_time_select, TimePicker: packages_time_picker, Popover: popover, Tooltip: packages_tooltip, MessageBox: message_box, Breadcrumb: packages_breadcrumb, BreadcrumbItem: packages_breadcrumb_item, Form: packages_form, FormItem: packages_form_item, Tabs: packages_tabs, TabPane: packages_tab_pane, Tag: packages_tag, Tree: packages_tree, Alert: packages_alert, Notification: notification, Slider: slider, Icon: packages_icon, Row: packages_row, Col: packages_col, Upload: packages_upload, Progress: packages_progress, Spinner: packages_spinner, Message: packages_message, Badge: badge, Card: card, Rate: rate, Steps: packages_steps, Step: packages_step, Carousel: carousel, Scrollbar: scrollbar, CarouselItem: carousel_item, Collapse: packages_collapse, CollapseItem: packages_collapse_item, Cascader: packages_cascader, ColorPicker: color_picker, Transfer: transfer, Container: packages_container, Header: header, Aside: aside, Main: packages_main, Footer: footer, Timeline: timeline, TimelineItem: timeline_item, Link: packages_link, Divider: divider, Image: packages_image, Calendar: calendar, Backtop: backtop, InfiniteScroll: infinite_scroll, PageHeader: page_header, CascaderPanel: packages_cascader_panel, Avatar: avatar, Drawer: drawer, Popconfirm: popconfirm }); /***/ }) /******/ ])["default"];