diff --git a/Modules/Page/Assets/js/PageRoutes.js b/Modules/Page/Assets/js/PageRoutes.js
index c8f407840..6c645a5c0 100644
--- a/Modules/Page/Assets/js/PageRoutes.js
+++ b/Modules/Page/Assets/js/PageRoutes.js
@@ -2,7 +2,7 @@ import PageTable from './components/PageTable.vue'
import PageTableServerSide from './components/PageTableServerSide.vue'
import PageForm from './components/PageForm.vue'
-const locales = window.locales;
+const locales = window.AsgardCMS.locales;
export default [
{
diff --git a/Themes/Adminlte/views/layouts/master.blade.php b/Themes/Adminlte/views/layouts/master.blade.php
index 01552d3fc..69095a88e 100644
--- a/Themes/Adminlte/views/layouts/master.blade.php
+++ b/Themes/Adminlte/views/layouts/master.blade.php
@@ -75,11 +75,10 @@
@endforeach
diff --git a/public/js/app.js b/public/js/app.js
index dd551c704..ed38114c6 100644
--- a/public/js/app.js
+++ b/public/js/app.js
@@ -283,11 +283,11 @@ Object.defineProperty(exports, "__esModule", {
});
exports["default"] = {
required: __webpack_require__(28),
- whitespace: __webpack_require__(58),
- type: __webpack_require__(59),
- range: __webpack_require__(60),
- "enum": __webpack_require__(61),
- pattern: __webpack_require__(62)
+ whitespace: __webpack_require__(59),
+ type: __webpack_require__(60),
+ range: __webpack_require__(61),
+ "enum": __webpack_require__(62),
+ pattern: __webpack_require__(63)
};
module.exports = exports['default'];
@@ -299,7 +299,7 @@ module.exports = exports['default'];
var bind = __webpack_require__(30);
-var isBuffer = __webpack_require__(93);
+var isBuffer = __webpack_require__(94);
/*global toString:true*/
@@ -11087,7 +11087,7 @@ module.exports = function normalizeComponent (
/* 8 */
/***/ (function(module, exports, __webpack_require__) {
-module.exports = __webpack_require__(92);
+module.exports = __webpack_require__(93);
/***/ }),
/* 9 */
@@ -11117,7 +11117,35 @@ module.exports = function ( delay, atBegin, callback ) {
/***/ }),
-/* 10 */,
+/* 10 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = {
+ methods: {
+ trans: function trans(string) {
+ // Makes a string: core.button.cancel | core.button.created at
+ // to: core["button.cancel"] | core["button.created at"]
+ var array = string.split('.');
+
+ if (array.length < 2) {
+ return this.$t(string);
+ }
+
+ var first = array.splice(0, 1);
+ var key = array.join('.');
+
+ return this.$t(first + '[\'' + key + '\']');
+ }
+ }
+};
+
+/***/ }),
/* 11 */
/***/ (function(module, exports, __webpack_require__) {
@@ -11705,7 +11733,7 @@ var _popup = __webpack_require__(21);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-var PopperJS = _vue2.default.prototype.$isServer ? function () {} : __webpack_require__(43);
+var PopperJS = _vue2.default.prototype.$isServer ? function () {} : __webpack_require__(44);
var stop = function stop(e) {
return e.stopPropagation();
};
@@ -12128,7 +12156,7 @@ var removeResizeListener = exports.removeResizeListener = function removeResizeL
exports.__esModule = true;
exports.i18n = exports.use = exports.t = undefined;
-var _zhCN = __webpack_require__(44);
+var _zhCN = __webpack_require__(45);
var _zhCN2 = _interopRequireDefault(_zhCN);
@@ -12136,11 +12164,11 @@ var _vue = __webpack_require__(3);
var _vue2 = _interopRequireDefault(_vue);
-var _deepmerge = __webpack_require__(45);
+var _deepmerge = __webpack_require__(46);
var _deepmerge2 = _interopRequireDefault(_deepmerge);
-var _format = __webpack_require__(46);
+var _format = __webpack_require__(47);
var _format2 = _interopRequireDefault(_format);
@@ -12233,7 +12261,7 @@ module.exports = exports['default'];
/* WEBPACK VAR INJECTION */(function(process) {
var utils = __webpack_require__(2);
-var normalizeHeaderName = __webpack_require__(96);
+var normalizeHeaderName = __webpack_require__(97);
var DEFAULT_CONTENT_TYPE = {
'Content-Type': 'application/x-www-form-urlencoded'
@@ -12323,7 +12351,7 @@ utils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {
module.exports = defaults;
-/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(95)))
+/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(96)))
/***/ }),
/* 19 */
@@ -12447,7 +12475,7 @@ var _merge = __webpack_require__(12);
var _merge2 = _interopRequireDefault(_merge);
-var _popupManager = __webpack_require__(42);
+var _popupManager = __webpack_require__(43);
var _popupManager2 = _interopRequireDefault(_popupManager);
@@ -13739,12 +13767,12 @@ module.exports = function bind(fn, thisArg) {
var utils = __webpack_require__(2);
-var settle = __webpack_require__(97);
-var buildURL = __webpack_require__(99);
-var parseHeaders = __webpack_require__(100);
-var isURLSameOrigin = __webpack_require__(101);
+var settle = __webpack_require__(98);
+var buildURL = __webpack_require__(100);
+var parseHeaders = __webpack_require__(101);
+var isURLSameOrigin = __webpack_require__(102);
var createError = __webpack_require__(32);
-var btoa = (typeof window !== 'undefined' && window.btoa && window.btoa.bind(window)) || __webpack_require__(102);
+var btoa = (typeof window !== 'undefined' && window.btoa && window.btoa.bind(window)) || __webpack_require__(103);
module.exports = function xhrAdapter(config) {
return new Promise(function dispatchXhrRequest(resolve, reject) {
@@ -13841,7 +13869,7 @@ module.exports = function xhrAdapter(config) {
// This is only done if running in a standard browser environment.
// Specifically not if we're in a web worker, or react-native.
if (utils.isStandardBrowserEnv()) {
- var cookies = __webpack_require__(103);
+ var cookies = __webpack_require__(104);
// Add xsrf header
var xsrfValue = (config.withCredentials || isURLSameOrigin(config.url)) && config.xsrfCookieName ?
@@ -13925,7 +13953,7 @@ module.exports = function xhrAdapter(config) {
"use strict";
-var enhanceError = __webpack_require__(98);
+var enhanceError = __webpack_require__(99);
/**
* Create an Error with the specified message, config, error code, request and response.
@@ -31071,7 +31099,7 @@ module.exports = Cancel;
}
}.call(this));
-/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(19), __webpack_require__(114)(module)))
+/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(19), __webpack_require__(115)(module)))
/***/ }),
/* 36 */
@@ -31217,29 +31245,29 @@ var _vue = __webpack_require__(3);
var _vue2 = _interopRequireDefault(_vue);
-var _vueI18n = __webpack_require__(137);
+var _vueI18n = __webpack_require__(39);
var _vueI18n2 = _interopRequireDefault(_vueI18n);
-var _vueRouter = __webpack_require__(39);
+var _vueRouter = __webpack_require__(40);
var _vueRouter2 = _interopRequireDefault(_vueRouter);
-var _elementUi = __webpack_require__(40);
+var _elementUi = __webpack_require__(41);
var _elementUi2 = _interopRequireDefault(_elementUi);
-var _vueDataTables = __webpack_require__(81);
+var _vueDataTables = __webpack_require__(82);
var _vueDataTables2 = _interopRequireDefault(_vueDataTables);
-__webpack_require__(82);
+__webpack_require__(83);
-var _en = __webpack_require__(88);
+var _en = __webpack_require__(89);
var _en2 = _interopRequireDefault(_en);
-var _PageRoutes = __webpack_require__(89);
+var _PageRoutes = __webpack_require__(90);
var _PageRoutes2 = _interopRequireDefault(_PageRoutes);
@@ -31249,17 +31277,19 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
-__webpack_require__(123);
+__webpack_require__(124);
_vue2.default.use(_elementUi2.default, { locale: _en2.default });
_vue2.default.use(_vueDataTables2.default, { locale: _en2.default });
_vue2.default.use(_vueI18n2.default);
_vue2.default.use(_vueRouter2.default);
-_vue2.default.component('ckeditor', __webpack_require__(124));
-_vue2.default.component('DeleteButton', __webpack_require__(131));
-_vue2.default.component('TagsInput', __webpack_require__(134));
+_vue2.default.component('ckeditor', __webpack_require__(125));
+_vue2.default.component('DeleteButton', __webpack_require__(132));
+_vue2.default.component('TagsInput', __webpack_require__(135));
+
+var currentLocale = window.AsgardCMS.currentLocale;
var router = new _vueRouter2.default({
mode: 'history',
@@ -31286,4910 +31316,4820 @@ var app = new _vue2.default({
"use strict";
Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/**
- * vue-router v2.7.0
- * (c) 2017 Evan You
- * @license MIT
- */
+/*!
+ * vue-i18n v7.2.0
+ * (c) 2017 kazuya kawaguchi
+ * Released under the MIT License.
+ */
/* */
-function assert (condition, message) {
- if (!condition) {
- throw new Error(("[vue-router] " + message))
- }
-}
+/**
+ * utilites
+ */
-function warn (condition, message) {
- if ("development" !== 'production' && !condition) {
- typeof console !== 'undefined' && console.warn(("[vue-router] " + message));
+function warn (msg, err) {
+ if (typeof console !== 'undefined') {
+ console.warn('[vue-i18n] ' + msg);
+ /* istanbul ignore if */
+ if (err) {
+ console.warn(err.stack);
+ }
}
}
-function isError (err) {
- return Object.prototype.toString.call(err).indexOf('Error') > -1
+function isObject (obj) {
+ return obj !== null && typeof obj === 'object'
}
-var View = {
- name: 'router-view',
- functional: true,
- props: {
- name: {
- type: String,
- default: 'default'
- }
- },
- render: function render (_, ref) {
- var props = ref.props;
- var children = ref.children;
- var parent = ref.parent;
- var data = ref.data;
+var toString = Object.prototype.toString;
+var OBJECT_STRING = '[object Object]';
+function isPlainObject (obj) {
+ return toString.call(obj) === OBJECT_STRING
+}
- data.routerView = true;
+function isNull (val) {
+ return val === null || val === undefined
+}
- // directly use parent context's createElement() function
- // so that components rendered by router-view can resolve named slots
- var h = parent.$createElement;
- var name = props.name;
- var route = parent.$route;
- var cache = parent._routerViewCache || (parent._routerViewCache = {});
+function parseArgs () {
+ var args = [], len = arguments.length;
+ while ( len-- ) args[ len ] = arguments[ len ];
- // determine current view depth, also check to see if the tree
- // has been toggled inactive but kept-alive.
- var depth = 0;
- var inactive = false;
- while (parent && parent._routerRoot !== parent) {
- if (parent.$vnode && parent.$vnode.data.routerView) {
- depth++;
- }
- if (parent._inactive) {
- inactive = true;
- }
- parent = parent.$parent;
+ var locale = null;
+ var params = null;
+ if (args.length === 1) {
+ if (isObject(args[0]) || Array.isArray(args[0])) {
+ params = args[0];
+ } else if (typeof args[0] === 'string') {
+ locale = args[0];
}
- data.routerViewDepth = depth;
-
- // render previous view if the tree is inactive and kept-alive
- if (inactive) {
- return h(cache[name], data, children)
+ } else if (args.length === 2) {
+ if (typeof args[0] === 'string') {
+ locale = args[0];
}
-
- var matched = route.matched[depth];
- // render empty node if no matched route
- if (!matched) {
- cache[name] = null;
- return h()
+ /* istanbul ignore if */
+ if (isObject(args[1]) || Array.isArray(args[1])) {
+ params = args[1];
}
+ }
- var component = cache[name] = matched.components[name];
+ return { locale: locale, params: params }
+}
- // attach instance registration hook
- // this will be called in the instance's injected lifecycle hooks
- data.registerRouteInstance = function (vm, val) {
- // val could be undefined for unregistration
- var current = matched.instances[name];
- if (
- (val && current !== vm) ||
- (!val && current === vm)
- ) {
- matched.instances[name] = val;
- }
- }
+function getOldChoiceIndexFixed (choice) {
+ return choice
+ ? choice > 1
+ ? 1
+ : 0
+ : 1
+}
- // also regiseter instance in prepatch hook
- // in case the same component instance is reused across different routes
- ;(data.hook || (data.hook = {})).prepatch = function (_, vnode) {
- matched.instances[name] = vnode.componentInstance;
- };
+function getChoiceIndex (choice, choicesLength) {
+ choice = Math.abs(choice);
- // resolve props
- data.props = resolveProps(route, matched.props && matched.props[name]);
+ if (choicesLength === 2) { return getOldChoiceIndexFixed(choice) }
- return h(component, data, children)
+ return choice ? Math.min(choice, 2) : 0
+}
+
+function fetchChoice (message, choice) {
+ /* istanbul ignore if */
+ if (!message && typeof message !== 'string') { return null }
+ var choices = message.split('|');
+
+ choice = getChoiceIndex(choice, choices.length);
+ if (!choices[choice]) { return message }
+ return choices[choice].trim()
+}
+
+function looseClone (obj) {
+ return JSON.parse(JSON.stringify(obj))
+}
+
+function remove (arr, item) {
+ if (arr.length) {
+ var index = arr.indexOf(item);
+ if (index > -1) {
+ return arr.splice(index, 1)
+ }
}
-};
+}
-function resolveProps (route, config) {
- switch (typeof config) {
- case 'undefined':
- return
- case 'object':
- return config
- case 'function':
- return config(route)
- case 'boolean':
- return config ? route.params : undefined
- default:
- if (true) {
- warn(
- false,
- "props in \"" + (route.path) + "\" is a " + (typeof config) + ", " +
- "expecting an object, function or boolean."
- );
+var hasOwnProperty = Object.prototype.hasOwnProperty;
+function hasOwn (obj, key) {
+ return hasOwnProperty.call(obj, key)
+}
+
+function merge (target) {
+ var arguments$1 = arguments;
+
+ var output = Object(target);
+ for (var i = 1; i < arguments.length; i++) {
+ var source = arguments$1[i];
+ if (source !== undefined && source !== null) {
+ var key = (void 0);
+ for (key in source) {
+ if (hasOwn(source, key)) {
+ if (isObject(source[key])) {
+ output[key] = merge(output[key], source[key]);
+ } else {
+ output[key] = source[key];
+ }
+ }
}
+ }
}
+ return output
}
-/* */
+var canUseDateTimeFormat =
+ typeof Intl !== 'undefined' && typeof Intl.DateTimeFormat !== 'undefined';
-var encodeReserveRE = /[!'()*]/g;
-var encodeReserveReplacer = function (c) { return '%' + c.charCodeAt(0).toString(16); };
-var commaRE = /%2C/g;
+var canUseNumberFormat =
+ typeof Intl !== 'undefined' && typeof Intl.NumberFormat !== 'undefined';
-// fixed encodeURIComponent which is more conformant to RFC3986:
-// - escapes [!'()*]
-// - preserve commas
-var encode = function (str) { return encodeURIComponent(str)
- .replace(encodeReserveRE, encodeReserveReplacer)
- .replace(commaRE, ','); };
+/* */
-var decode = decodeURIComponent;
+function extend (Vue) {
+ Vue.prototype.$t = function (key) {
+ var values = [], len = arguments.length - 1;
+ while ( len-- > 0 ) values[ len ] = arguments[ len + 1 ];
-function resolveQuery (
- query,
- extraQuery,
- _parseQuery
-) {
- if ( extraQuery === void 0 ) extraQuery = {};
+ var i18n = this.$i18n;
+ return i18n._t.apply(i18n, [ key, i18n.locale, i18n._getMessages(), this ].concat( values ))
+ };
- var parse = _parseQuery || parseQuery;
- var parsedQuery;
- try {
- parsedQuery = parse(query || '');
- } catch (e) {
- "development" !== 'production' && warn(false, e.message);
- parsedQuery = {};
- }
- for (var key in extraQuery) {
- var val = extraQuery[key];
- parsedQuery[key] = Array.isArray(val) ? val.slice() : val;
- }
- return parsedQuery
-}
+ Vue.prototype.$tc = function (key, choice) {
+ var values = [], len = arguments.length - 2;
+ while ( len-- > 0 ) values[ len ] = arguments[ len + 2 ];
-function parseQuery (query) {
- var res = {};
+ var i18n = this.$i18n;
+ return i18n._tc.apply(i18n, [ key, i18n.locale, i18n._getMessages(), this, choice ].concat( values ))
+ };
- query = query.trim().replace(/^(\?|#|&)/, '');
+ Vue.prototype.$te = function (key, locale) {
+ var i18n = this.$i18n;
+ return i18n._te(key, i18n.locale, i18n._getMessages(), locale)
+ };
- if (!query) {
- return res
- }
+ Vue.prototype.$d = function (value) {
+ var args = [], len = arguments.length - 1;
+ while ( len-- > 0 ) args[ len ] = arguments[ len + 1 ];
- query.split('&').forEach(function (param) {
- var parts = param.replace(/\+/g, ' ').split('=');
- var key = decode(parts.shift());
- var val = parts.length > 0
- ? decode(parts.join('='))
- : null;
+ return (ref = this.$i18n).d.apply(ref, [ value ].concat( args ))
+ var ref;
+ };
- if (res[key] === undefined) {
- res[key] = val;
- } else if (Array.isArray(res[key])) {
- res[key].push(val);
- } else {
- res[key] = [res[key], val];
- }
- });
+ Vue.prototype.$n = function (value) {
+ var args = [], len = arguments.length - 1;
+ while ( len-- > 0 ) args[ len ] = arguments[ len + 1 ];
- return res
+ return (ref = this.$i18n).n.apply(ref, [ value ].concat( args ))
+ var ref;
+ };
}
-function stringifyQuery (obj) {
- var res = obj ? Object.keys(obj).map(function (key) {
- var val = obj[key];
+/* */
- if (val === undefined) {
- return ''
- }
+var mixin = {
+ beforeCreate: function beforeCreate () {
+ var options = this.$options;
+ options.i18n = options.i18n || (options.__i18n ? {} : null);
- if (val === null) {
- return encode(key)
- }
+ if (options.i18n) {
+ if (options.i18n instanceof VueI18n) {
+ // init locale messages via custom blocks
+ if (options.__i18n) {
+ try {
+ var localeMessages = {};
+ options.__i18n.forEach(function (resource) {
+ localeMessages = merge(localeMessages, JSON.parse(resource));
+ });
+ Object.keys(localeMessages).forEach(function (locale) {
+ options.i18n.mergeLocaleMessage(locale, localeMessages[locale]);
+ });
+ } catch (e) {
+ if (true) {
+ warn("Cannot parse locale messages via custom blocks.", e);
+ }
+ }
+ }
+ this._i18n = options.i18n;
+ this._i18nWatcher = this._i18n.watchI18nData();
+ this._i18n.subscribeDataChanging(this);
+ this._subscribing = true;
+ } else if (isPlainObject(options.i18n)) {
+ // component local i18n
+ if (this.$root && this.$root.$i18n && this.$root.$i18n instanceof VueI18n) {
+ options.i18n.root = this.$root.$i18n;
+ options.i18n.fallbackLocale = this.$root.$i18n.fallbackLocale;
+ options.i18n.silentTranslationWarn = this.$root.$i18n.silentTranslationWarn;
+ }
- if (Array.isArray(val)) {
- var result = [];
- val.forEach(function (val2) {
- if (val2 === undefined) {
- return
+ // init locale messages via custom blocks
+ if (options.__i18n) {
+ try {
+ var localeMessages$1 = {};
+ options.__i18n.forEach(function (resource) {
+ localeMessages$1 = merge(localeMessages$1, JSON.parse(resource));
+ });
+ options.i18n.messages = localeMessages$1;
+ } catch (e) {
+ if (true) {
+ warn("Cannot parse locale messages via custom blocks.", e);
+ }
+ }
}
- if (val2 === null) {
- result.push(encode(key));
- } else {
- result.push(encode(key) + '=' + encode(val2));
+
+ this._i18n = new VueI18n(options.i18n);
+ this._i18nWatcher = this._i18n.watchI18nData();
+ this._i18n.subscribeDataChanging(this);
+ this._subscribing = true;
+
+ if (options.i18n.sync === undefined || !!options.i18n.sync) {
+ this._localeWatcher = this.$i18n.watchLocale();
}
- });
- return result.join('&')
+ } else {
+ if (true) {
+ warn("Cannot be interpreted 'i18n' option.");
+ }
+ }
+ } else if (this.$root && this.$root.$i18n && this.$root.$i18n instanceof VueI18n) {
+ // root i18n
+ this._i18n = this.$root.$i18n;
+ this._i18n.subscribeDataChanging(this);
+ this._subscribing = true;
+ } else if (options.parent && options.parent.$i18n && options.parent.$i18n instanceof VueI18n) {
+ // parent i18n
+ this._i18n = options.parent.$i18n;
+ this._i18n.subscribeDataChanging(this);
+ this._subscribing = true;
}
+ },
- return encode(key) + '=' + encode(val)
- }).filter(function (x) { return x.length > 0; }).join('&') : null;
- return res ? ("?" + res) : ''
-}
+ beforeDestroy: function beforeDestroy () {
+ if (!this._i18n) { return }
-/* */
+ if (this._subscribing) {
+ this._i18n.unsubscribeDataChanging(this);
+ delete this._subscribing;
+ }
+ if (this._i18nWatcher) {
+ this._i18nWatcher();
+ delete this._i18nWatcher;
+ }
-var trailingSlashRE = /\/?$/;
+ if (this._localeWatcher) {
+ this._localeWatcher();
+ delete this._localeWatcher;
+ }
-function createRoute (
- record,
- location,
- redirectedFrom,
- router
-) {
- var stringifyQuery$$1 = router && router.options.stringifyQuery;
- var route = {
- name: location.name || (record && record.name),
- meta: (record && record.meta) || {},
- path: location.path || '/',
- hash: location.hash || '',
- query: location.query || {},
- params: location.params || {},
- fullPath: getFullPath(location, stringifyQuery$$1),
- matched: record ? formatMatch(record) : []
- };
- if (redirectedFrom) {
- route.redirectedFrom = getFullPath(redirectedFrom, stringifyQuery$$1);
+ this._i18n = null;
}
- return Object.freeze(route)
-}
+};
-// the starting route that represents the initial state
-var START = createRoute(null, {
- path: '/'
-});
+/* */
-function formatMatch (record) {
- var res = [];
- while (record) {
- res.unshift(record);
- record = record.parent;
- }
- return res
-}
+var component = {
+ name: 'i18n',
+ functional: true,
+ props: {
+ tag: {
+ type: String,
+ default: 'span'
+ },
+ path: {
+ type: String,
+ required: true
+ },
+ locale: {
+ type: String
+ },
+ places: {
+ type: [Array, Object]
+ }
+ },
+ render: function render (h, ref) {
+ var props = ref.props;
+ var data = ref.data;
+ var children = ref.children;
+ var parent = ref.parent;
-function getFullPath (
- ref,
- _stringifyQuery
-) {
- var path = ref.path;
- var query = ref.query; if ( query === void 0 ) query = {};
- var hash = ref.hash; if ( hash === void 0 ) hash = '';
+ var i18n = parent.$i18n;
- var stringify = _stringifyQuery || stringifyQuery;
- return (path || '/') + stringify(query) + hash
-}
+ children = (children || []).filter(function (child) {
+ return child.tag || (child.text = child.text.trim())
+ });
-function isSameRoute (a, b) {
- if (b === START) {
- return a === b
- } else if (!b) {
- return false
- } else if (a.path && b.path) {
- return (
- a.path.replace(trailingSlashRE, '') === b.path.replace(trailingSlashRE, '') &&
- a.hash === b.hash &&
- isObjectEqual(a.query, b.query)
- )
- } else if (a.name && b.name) {
- return (
- a.name === b.name &&
- a.hash === b.hash &&
- isObjectEqual(a.query, b.query) &&
- isObjectEqual(a.params, b.params)
- )
- } else {
- return false
- }
-}
-
-function isObjectEqual (a, b) {
- if ( a === void 0 ) a = {};
- if ( b === void 0 ) b = {};
-
- var aKeys = Object.keys(a);
- var bKeys = Object.keys(b);
- if (aKeys.length !== bKeys.length) {
- return false
- }
- return aKeys.every(function (key) {
- var aVal = a[key];
- var bVal = b[key];
- // check nested equality
- if (typeof aVal === 'object' && typeof bVal === 'object') {
- return isObjectEqual(aVal, bVal)
- }
- return String(aVal) === String(bVal)
- })
-}
-
-function isIncludedRoute (current, target) {
- return (
- current.path.replace(trailingSlashRE, '/').indexOf(
- target.path.replace(trailingSlashRE, '/')
- ) === 0 &&
- (!target.hash || current.hash === target.hash) &&
- queryIncludes(current.query, target.query)
- )
-}
-
-function queryIncludes (current, target) {
- for (var key in target) {
- if (!(key in current)) {
- return false
- }
- }
- return true
-}
-
-/* */
-
-// work around weird flow bug
-var toTypes = [String, Object];
-var eventTypes = [String, Array];
-
-var Link = {
- name: 'router-link',
- props: {
- to: {
- type: toTypes,
- required: true
- },
- tag: {
- type: String,
- default: 'a'
- },
- exact: Boolean,
- append: Boolean,
- replace: Boolean,
- activeClass: String,
- exactActiveClass: String,
- event: {
- type: eventTypes,
- default: 'click'
+ if (!i18n) {
+ if (true) {
+ warn('Cannot find VueI18n instance!');
+ }
+ return children
}
- },
- render: function render (h) {
- var this$1 = this;
- var router = this.$router;
- var current = this.$route;
- var ref = router.resolve(this.to, current, this.append);
- var location = ref.location;
- var route = ref.route;
- var href = ref.href;
+ var path = props.path;
+ var locale = props.locale;
- var classes = {};
- var globalActiveClass = router.options.linkActiveClass;
- var globalExactActiveClass = router.options.linkExactActiveClass;
- // Support global empty active class
- var activeClassFallback = globalActiveClass == null
- ? 'router-link-active'
- : globalActiveClass;
- var exactActiveClassFallback = globalExactActiveClass == null
- ? 'router-link-exact-active'
- : globalExactActiveClass;
- var activeClass = this.activeClass == null
- ? activeClassFallback
- : this.activeClass;
- var exactActiveClass = this.exactActiveClass == null
- ? exactActiveClassFallback
- : this.exactActiveClass;
- var compareTarget = location.path
- ? createRoute(null, location, null, router)
- : route;
+ var params = {};
+ var places = props.places || {};
- classes[exactActiveClass] = isSameRoute(current, compareTarget);
- classes[activeClass] = this.exact
- ? classes[exactActiveClass]
- : isIncludedRoute(current, compareTarget);
+ var hasPlaces = Array.isArray(places)
+ ? places.length > 0
+ : Object.keys(places).length > 0;
- var handler = function (e) {
- if (guardEvent(e)) {
- if (this$1.replace) {
- router.replace(location);
- } else {
- router.push(location);
- }
+ var everyPlace = children.every(function (child) {
+ if (child.data && child.data.attrs) {
+ var place = child.data.attrs.place;
+ return (typeof place !== 'undefined') && place !== ''
}
- };
+ });
- var on = { click: guardEvent };
- if (Array.isArray(this.event)) {
- this.event.forEach(function (e) { on[e] = handler; });
- } else {
- on[this.event] = handler;
+ if (hasPlaces && children.length > 0 && !everyPlace) {
+ warn('If places prop is set, all child elements must have place prop set.');
}
- var data = {
- class: classes
- };
-
- if (this.tag === 'a') {
- data.on = on;
- data.attrs = { href: href };
+ if (Array.isArray(places)) {
+ places.forEach(function (el, i) {
+ params[i] = el;
+ });
} else {
- // find the first child and apply listener and href
- var a = findAnchor(this.$slots.default);
- if (a) {
- // in case the is a static node
- a.isStatic = false;
- var extend = _Vue.util.extend;
- var aData = a.data = extend({}, a.data);
- aData.on = on;
- var aAttrs = a.data.attrs = extend({}, a.data.attrs);
- aAttrs.href = href;
- } else {
- // doesn't have child, apply listener to self
- data.on = on;
- }
+ Object.keys(places).forEach(function (key) {
+ params[key] = places[key];
+ });
}
- return h(this.tag, data, this.$slots.default)
- }
-};
+ children.forEach(function (child, i) {
+ var key = everyPlace
+ ? ("" + (child.data.attrs.place))
+ : ("" + i);
+ params[key] = child;
+ });
-function guardEvent (e) {
- // don't redirect with control keys
- if (e.metaKey || e.altKey || e.ctrlKey || e.shiftKey) { return }
- // don't redirect when preventDefault called
- if (e.defaultPrevented) { return }
- // don't redirect on right click
- if (e.button !== undefined && e.button !== 0) { return }
- // don't redirect if `target="_blank"`
- if (e.currentTarget && e.currentTarget.getAttribute) {
- var target = e.currentTarget.getAttribute('target');
- if (/\b_blank\b/i.test(target)) { return }
- }
- // this may be a Weex event which doesn't have this method
- if (e.preventDefault) {
- e.preventDefault();
+ return h(props.tag, data, i18n.i(path, locale, params))
}
- return true
-}
+};
-function findAnchor (children) {
- if (children) {
- var child;
- for (var i = 0; i < children.length; i++) {
- child = children[i];
- if (child.tag === 'a') {
- return child
- }
- if (child.children && (child = findAnchor(child.children))) {
- return child
- }
- }
- }
-}
+var Vue;
-var _Vue;
+function install (_Vue) {
+ Vue = _Vue;
-function install (Vue) {
- if (install.installed) { return }
+ var version = (Vue.version && Number(Vue.version.split('.')[0])) || -1;
+ /* istanbul ignore if */
+ if ("development" !== 'production' && install.installed) {
+ warn('already installed.');
+ return
+ }
install.installed = true;
- _Vue = Vue;
-
- var isDef = function (v) { return v !== undefined; };
-
- var registerInstance = function (vm, callVal) {
- var i = vm.$options._parentVnode;
- if (isDef(i) && isDef(i = i.data) && isDef(i = i.registerRouteInstance)) {
- i(vm, callVal);
- }
- };
-
- Vue.mixin({
- beforeCreate: function beforeCreate () {
- if (isDef(this.$options.router)) {
- this._routerRoot = this;
- this._router = this.$options.router;
- this._router.init(this);
- Vue.util.defineReactive(this, '_route', this._router.history.current);
- } else {
- this._routerRoot = (this.$parent && this.$parent._routerRoot) || this;
- }
- registerInstance(this, this);
- },
- destroyed: function destroyed () {
- registerInstance(this);
- }
- });
-
- Object.defineProperty(Vue.prototype, '$router', {
- get: function get () { return this._routerRoot._router }
- });
+ /* istanbul ignore if */
+ if ("development" !== 'production' && version < 2) {
+ warn(("vue-i18n (" + (install.version) + ") need to use Vue 2.0 or later (Vue: " + (Vue.version) + ")."));
+ return
+ }
- Object.defineProperty(Vue.prototype, '$route', {
- get: function get () { return this._routerRoot._route }
+ Object.defineProperty(Vue.prototype, '$i18n', {
+ get: function get () { return this._i18n }
});
- Vue.component('router-view', View);
- Vue.component('router-link', Link);
+ extend(Vue);
+ Vue.mixin(mixin);
+ Vue.component(component.name, component);
+ // use object-based merge strategy
var strats = Vue.config.optionMergeStrategies;
- // use the same hook merging strategy for route hooks
- strats.beforeRouteEnter = strats.beforeRouteLeave = strats.beforeRouteUpdate = strats.created;
+ strats.i18n = strats.methods;
}
/* */
-var inBrowser = typeof window !== 'undefined';
-
-/* */
+var BaseFormatter = function BaseFormatter () {
+ this._caches = Object.create(null);
+};
-function resolvePath (
- relative,
- base,
- append
-) {
- var firstChar = relative.charAt(0);
- if (firstChar === '/') {
- return relative
+BaseFormatter.prototype.interpolate = function interpolate (message, values) {
+ var tokens = this._caches[message];
+ if (!tokens) {
+ tokens = parse(message);
+ this._caches[message] = tokens;
}
+ return compile(tokens, values)
+};
- if (firstChar === '?' || firstChar === '#') {
- return base + relative
- }
+var RE_TOKEN_LIST_VALUE = /^(\d)+/;
+var RE_TOKEN_NAMED_VALUE = /^(\w)+/;
- var stack = base.split('/');
+function parse (format) {
+ var tokens = [];
+ var position = 0;
- // remove trailing segment if:
- // - not appending
- // - appending to trailing slash (last segment is empty)
- if (!append || !stack[stack.length - 1]) {
- stack.pop();
- }
+ var text = '';
+ while (position < format.length) {
+ var char = format[position++];
+ if (char === '{') {
+ if (text) {
+ tokens.push({ type: 'text', value: text });
+ }
- // resolve relative path
- var segments = relative.replace(/^\//, '').split('/');
- for (var i = 0; i < segments.length; i++) {
- var segment = segments[i];
- if (segment === '..') {
- stack.pop();
- } else if (segment !== '.') {
- stack.push(segment);
+ text = '';
+ var sub = '';
+ char = format[position++];
+ while (char !== '}') {
+ sub += char;
+ char = format[position++];
+ }
+
+ var type = RE_TOKEN_LIST_VALUE.test(sub)
+ ? 'list'
+ : RE_TOKEN_NAMED_VALUE.test(sub)
+ ? 'named'
+ : 'unknown';
+ tokens.push({ value: sub, type: type });
+ } else if (char === '%') {
+ // when found rails i18n syntax, skip text capture
+ if (format[(position)] !== '{') {
+ text += char;
+ }
+ } else {
+ text += char;
}
}
- // ensure leading slash
- if (stack[0] !== '') {
- stack.unshift('');
- }
+ text && tokens.push({ type: 'text', value: text });
- return stack.join('/')
+ return tokens
}
-function parsePath (path) {
- var hash = '';
- var query = '';
-
- var hashIndex = path.indexOf('#');
- if (hashIndex >= 0) {
- hash = path.slice(hashIndex);
- path = path.slice(0, hashIndex);
- }
+function compile (tokens, values) {
+ var compiled = [];
+ var index = 0;
- var queryIndex = path.indexOf('?');
- if (queryIndex >= 0) {
- query = path.slice(queryIndex + 1);
- path = path.slice(0, queryIndex);
- }
+ var mode = Array.isArray(values)
+ ? 'list'
+ : isObject(values)
+ ? 'named'
+ : 'unknown';
+ if (mode === 'unknown') { return compiled }
- return {
- path: path,
- query: query,
- hash: hash
+ while (index < tokens.length) {
+ var token = tokens[index];
+ switch (token.type) {
+ case 'text':
+ compiled.push(token.value);
+ break
+ case 'list':
+ compiled.push(values[parseInt(token.value, 10)]);
+ break
+ case 'named':
+ if (mode === 'named') {
+ compiled.push((values)[token.value]);
+ } else {
+ if (true) {
+ warn(("Type of token '" + (token.type) + "' and format of value '" + mode + "' don't match!"));
+ }
+ }
+ break
+ case 'unknown':
+ if (true) {
+ warn("Detect 'unknown' type of token!");
+ }
+ break
+ }
+ index++;
}
-}
-function cleanPath (path) {
- return path.replace(/\/\//g, '/')
+ return compiled
}
-var index$1 = Array.isArray || function (arr) {
- return Object.prototype.toString.call(arr) == '[object Array]';
-};
-
-/**
- * Expose `pathToRegexp`.
- */
-var index = pathToRegexp;
-var parse_1 = parse;
-var compile_1 = compile;
-var tokensToFunction_1 = tokensToFunction;
-var tokensToRegExp_1 = tokensToRegExp;
+/* */
/**
- * The main path matching regexp utility.
- *
- * @type {RegExp}
+ * Path paerser
+ * - Inspired:
+ * Vue.js Path parser
*/
-var PATH_REGEXP = new RegExp([
- // Match escaped characters that would otherwise appear in future matches.
- // This allows the user to escape special characters that won't transform.
- '(\\\\.)',
- // Match Express-style parameters and un-named parameters with a prefix
- // and optional suffixes. Matches appear as:
- //
- // "/:test(\\d+)?" => ["/", "test", "\d+", undefined, "?", undefined]
- // "/route(\\d+)" => [undefined, undefined, undefined, "\d+", undefined, undefined]
- // "/*" => ["/", undefined, undefined, undefined, undefined, "*"]
- '([\\/.])?(?:(?:\\:(\\w+)(?:\\(((?:\\\\.|[^\\\\()])+)\\))?|\\(((?:\\\\.|[^\\\\()])+)\\))([+*?])?|(\\*))'
-].join('|'), 'g');
-/**
- * Parse a string for the raw tokens.
- *
- * @param {string} str
- * @param {Object=} options
- * @return {!Array}
- */
-function parse (str, options) {
- var tokens = [];
- var key = 0;
- var index = 0;
- var path = '';
- var defaultDelimiter = options && options.delimiter || '/';
- var res;
+// actions
+var APPEND = 0;
+var PUSH = 1;
+var INC_SUB_PATH_DEPTH = 2;
+var PUSH_SUB_PATH = 3;
- while ((res = PATH_REGEXP.exec(str)) != null) {
- var m = res[0];
- var escaped = res[1];
- var offset = res.index;
- path += str.slice(index, offset);
- index = offset + m.length;
+// states
+var BEFORE_PATH = 0;
+var IN_PATH = 1;
+var BEFORE_IDENT = 2;
+var IN_IDENT = 3;
+var IN_SUB_PATH = 4;
+var IN_SINGLE_QUOTE = 5;
+var IN_DOUBLE_QUOTE = 6;
+var AFTER_PATH = 7;
+var ERROR = 8;
- // Ignore already escaped sequences.
- if (escaped) {
- path += escaped[1];
- continue
- }
+var pathStateMachine = [];
- var next = str[index];
- var prefix = res[2];
- var name = res[3];
- var capture = res[4];
- var group = res[5];
- var modifier = res[6];
- var asterisk = res[7];
+pathStateMachine[BEFORE_PATH] = {
+ 'ws': [BEFORE_PATH],
+ 'ident': [IN_IDENT, APPEND],
+ '[': [IN_SUB_PATH],
+ 'eof': [AFTER_PATH]
+};
- // Push the current path onto the tokens.
- if (path) {
- tokens.push(path);
- path = '';
- }
+pathStateMachine[IN_PATH] = {
+ 'ws': [IN_PATH],
+ '.': [BEFORE_IDENT],
+ '[': [IN_SUB_PATH],
+ 'eof': [AFTER_PATH]
+};
- var partial = prefix != null && next != null && next !== prefix;
- var repeat = modifier === '+' || modifier === '*';
- var optional = modifier === '?' || modifier === '*';
- var delimiter = res[2] || defaultDelimiter;
- var pattern = capture || group;
+pathStateMachine[BEFORE_IDENT] = {
+ 'ws': [BEFORE_IDENT],
+ 'ident': [IN_IDENT, APPEND],
+ '0': [IN_IDENT, APPEND],
+ 'number': [IN_IDENT, APPEND]
+};
- tokens.push({
- name: name || key++,
- prefix: prefix || '',
- delimiter: delimiter,
- optional: optional,
- repeat: repeat,
- partial: partial,
- asterisk: !!asterisk,
- pattern: pattern ? escapeGroup(pattern) : (asterisk ? '.*' : '[^' + escapeString(delimiter) + ']+?')
- });
- }
+pathStateMachine[IN_IDENT] = {
+ 'ident': [IN_IDENT, APPEND],
+ '0': [IN_IDENT, APPEND],
+ 'number': [IN_IDENT, APPEND],
+ 'ws': [IN_PATH, PUSH],
+ '.': [BEFORE_IDENT, PUSH],
+ '[': [IN_SUB_PATH, PUSH],
+ 'eof': [AFTER_PATH, PUSH]
+};
- // Match any characters still remaining.
- if (index < str.length) {
- path += str.substr(index);
- }
+pathStateMachine[IN_SUB_PATH] = {
+ "'": [IN_SINGLE_QUOTE, APPEND],
+ '"': [IN_DOUBLE_QUOTE, APPEND],
+ '[': [IN_SUB_PATH, INC_SUB_PATH_DEPTH],
+ ']': [IN_PATH, PUSH_SUB_PATH],
+ 'eof': ERROR,
+ 'else': [IN_SUB_PATH, APPEND]
+};
- // If the path exists, push it onto the end.
- if (path) {
- tokens.push(path);
- }
+pathStateMachine[IN_SINGLE_QUOTE] = {
+ "'": [IN_SUB_PATH, APPEND],
+ 'eof': ERROR,
+ 'else': [IN_SINGLE_QUOTE, APPEND]
+};
- return tokens
-}
+pathStateMachine[IN_DOUBLE_QUOTE] = {
+ '"': [IN_SUB_PATH, APPEND],
+ 'eof': ERROR,
+ 'else': [IN_DOUBLE_QUOTE, APPEND]
+};
/**
- * Compile a string to a template function for the path.
- *
- * @param {string} str
- * @param {Object=} options
- * @return {!function(Object=, Object=)}
+ * Check if an expression is a literal value.
*/
-function compile (str, options) {
- return tokensToFunction(parse(str, options))
-}
-/**
- * Prettier encoding of URI path segments.
- *
- * @param {string}
- * @return {string}
- */
-function encodeURIComponentPretty (str) {
- return encodeURI(str).replace(/[\/?#]/g, function (c) {
- return '%' + c.charCodeAt(0).toString(16).toUpperCase()
- })
+var literalValueRE = /^\s?(true|false|-?[\d.]+|'[^']*'|"[^"]*")\s?$/;
+function isLiteral (exp) {
+ return literalValueRE.test(exp)
}
/**
- * Encode the asterisk parameter. Similar to `pretty`, but allows slashes.
- *
- * @param {string}
- * @return {string}
+ * Strip quotes from a string
*/
-function encodeAsterisk (str) {
- return encodeURI(str).replace(/[?#]/g, function (c) {
- return '%' + c.charCodeAt(0).toString(16).toUpperCase()
- })
+
+function stripQuotes (str) {
+ var a = str.charCodeAt(0);
+ var b = str.charCodeAt(str.length - 1);
+ return a === b && (a === 0x22 || a === 0x27)
+ ? str.slice(1, -1)
+ : str
}
/**
- * Expose a method for transforming tokens into the path function.
+ * Determine the type of a character in a keypath.
*/
-function tokensToFunction (tokens) {
- // Compile all the tokens into regexps.
- var matches = new Array(tokens.length);
-
- // Compile all the patterns before compilation.
- for (var i = 0; i < tokens.length; i++) {
- if (typeof tokens[i] === 'object') {
- matches[i] = new RegExp('^(?:' + tokens[i].pattern + ')$');
- }
- }
-
- return function (obj, opts) {
- var path = '';
- var data = obj || {};
- var options = opts || {};
- var encode = options.pretty ? encodeURIComponentPretty : encodeURIComponent;
-
- for (var i = 0; i < tokens.length; i++) {
- var token = tokens[i];
-
- if (typeof token === 'string') {
- path += token;
-
- continue
- }
-
- var value = data[token.name];
- var segment;
-
- if (value == null) {
- if (token.optional) {
- // Prepend partial segment prefixes.
- if (token.partial) {
- path += token.prefix;
- }
-
- continue
- } else {
- throw new TypeError('Expected "' + token.name + '" to be defined')
- }
- }
-
- if (index$1(value)) {
- if (!token.repeat) {
- throw new TypeError('Expected "' + token.name + '" to not repeat, but received `' + JSON.stringify(value) + '`')
- }
-
- if (value.length === 0) {
- if (token.optional) {
- continue
- } else {
- throw new TypeError('Expected "' + token.name + '" to not be empty')
- }
- }
- for (var j = 0; j < value.length; j++) {
- segment = encode(value[j]);
+function getPathCharType (ch) {
+ if (ch === undefined || ch === null) { return 'eof' }
- if (!matches[i].test(segment)) {
- throw new TypeError('Expected all "' + token.name + '" to match "' + token.pattern + '", but received `' + JSON.stringify(segment) + '`')
- }
+ var code = ch.charCodeAt(0);
- path += (j === 0 ? token.prefix : token.delimiter) + segment;
- }
+ switch (code) {
+ case 0x5B: // [
+ case 0x5D: // ]
+ case 0x2E: // .
+ case 0x22: // "
+ case 0x27: // '
+ case 0x30: // 0
+ return ch
- continue
- }
+ case 0x5F: // _
+ case 0x24: // $
+ case 0x2D: // -
+ return 'ident'
- segment = token.asterisk ? encodeAsterisk(value) : encode(value);
+ case 0x20: // Space
+ case 0x09: // Tab
+ case 0x0A: // Newline
+ case 0x0D: // Return
+ case 0xA0: // No-break space
+ case 0xFEFF: // Byte Order Mark
+ case 0x2028: // Line Separator
+ case 0x2029: // Paragraph Separator
+ return 'ws'
+ }
- if (!matches[i].test(segment)) {
- throw new TypeError('Expected "' + token.name + '" to match "' + token.pattern + '", but received "' + segment + '"')
- }
+ // a-z, A-Z
+ if ((code >= 0x61 && code <= 0x7A) || (code >= 0x41 && code <= 0x5A)) {
+ return 'ident'
+ }
- path += token.prefix + segment;
- }
+ // 1-9
+ if (code >= 0x31 && code <= 0x39) { return 'number' }
- return path
- }
+ return 'else'
}
/**
- * Escape a regular expression string.
- *
- * @param {string} str
- * @return {string}
+ * Format a subPath, return its plain form if it is
+ * a literal string or number. Otherwise prepend the
+ * dynamic indicator (*).
*/
-function escapeString (str) {
- return str.replace(/([.+*?=^!:${}()[\]|\/\\])/g, '\\$1')
-}
-/**
- * Escape the capturing group by escaping special characters and meaning.
- *
- * @param {string} group
- * @return {string}
- */
-function escapeGroup (group) {
- return group.replace(/([=!:$\/()])/g, '\\$1')
-}
+function formatSubPath (path) {
+ var trimmed = path.trim();
+ // invalid leading 0
+ if (path.charAt(0) === '0' && isNaN(path)) { return false }
-/**
- * Attach the keys as a property of the regexp.
- *
- * @param {!RegExp} re
- * @param {Array} keys
- * @return {!RegExp}
- */
-function attachKeys (re, keys) {
- re.keys = keys;
- return re
+ return isLiteral(trimmed) ? stripQuotes(trimmed) : '*' + trimmed
}
/**
- * Get the flags for a regexp from the options.
- *
- * @param {Object} options
- * @return {string}
+ * Parse a string path into an array of segments
*/
-function flags (options) {
- return options.sensitive ? '' : 'i'
-}
-/**
- * Pull out keys from a regexp.
- *
- * @param {!RegExp} path
- * @param {!Array} keys
- * @return {!RegExp}
- */
-function regexpToRegexp (path, keys) {
- // Use a negative lookahead to match only capturing groups.
- var groups = path.source.match(/\((?!\?)/g);
+function parse$1 (path) {
+ var keys = [];
+ var index = -1;
+ var mode = BEFORE_PATH;
+ var subPathDepth = 0;
+ var c;
+ var key;
+ var newChar;
+ var type;
+ var transition;
+ var action;
+ var typeMap;
+ var actions = [];
- if (groups) {
- for (var i = 0; i < groups.length; i++) {
- keys.push({
- name: i,
- prefix: null,
- delimiter: null,
- optional: false,
- repeat: false,
- partial: false,
- asterisk: false,
- pattern: null
- });
+ actions[PUSH] = function () {
+ if (key !== undefined) {
+ keys.push(key);
+ key = undefined;
}
- }
-
- return attachKeys(path, keys)
-}
-
-/**
- * Transform an array into a regexp.
- *
- * @param {!Array} path
- * @param {Array} keys
- * @param {!Object} options
- * @return {!RegExp}
- */
-function arrayToRegexp (path, keys, options) {
- var parts = [];
-
- for (var i = 0; i < path.length; i++) {
- parts.push(pathToRegexp(path[i], keys, options).source);
- }
+ };
- var regexp = new RegExp('(?:' + parts.join('|') + ')', flags(options));
+ actions[APPEND] = function () {
+ if (key === undefined) {
+ key = newChar;
+ } else {
+ key += newChar;
+ }
+ };
- return attachKeys(regexp, keys)
-}
+ actions[INC_SUB_PATH_DEPTH] = function () {
+ actions[APPEND]();
+ subPathDepth++;
+ };
-/**
- * Create a path regexp from string input.
- *
- * @param {string} path
- * @param {!Array} keys
- * @param {!Object} options
- * @return {!RegExp}
- */
-function stringToRegexp (path, keys, options) {
- return tokensToRegExp(parse(path, options), keys, options)
-}
+ actions[PUSH_SUB_PATH] = function () {
+ if (subPathDepth > 0) {
+ subPathDepth--;
+ mode = IN_SUB_PATH;
+ actions[APPEND]();
+ } else {
+ subPathDepth = 0;
+ key = formatSubPath(key);
+ if (key === false) {
+ return false
+ } else {
+ actions[PUSH]();
+ }
+ }
+ };
-/**
- * Expose a function for taking tokens and returning a RegExp.
- *
- * @param {!Array} tokens
- * @param {(Array|Object)=} keys
- * @param {Object=} options
- * @return {!RegExp}
- */
-function tokensToRegExp (tokens, keys, options) {
- if (!index$1(keys)) {
- options = /** @type {!Object} */ (keys || options);
- keys = [];
+ function maybeUnescapeQuote () {
+ var nextChar = path[index + 1];
+ if ((mode === IN_SINGLE_QUOTE && nextChar === "'") ||
+ (mode === IN_DOUBLE_QUOTE && nextChar === '"')) {
+ index++;
+ newChar = '\\' + nextChar;
+ actions[APPEND]();
+ return true
+ }
}
- options = options || {};
-
- var strict = options.strict;
- var end = options.end !== false;
- var route = '';
-
- // Iterate over the tokens and create our regexp string.
- for (var i = 0; i < tokens.length; i++) {
- var token = tokens[i];
+ while (mode !== null) {
+ index++;
+ c = path[index];
- if (typeof token === 'string') {
- route += escapeString(token);
- } else {
- var prefix = escapeString(token.prefix);
- var capture = '(?:' + token.pattern + ')';
+ if (c === '\\' && maybeUnescapeQuote()) {
+ continue
+ }
- keys.push(token);
+ type = getPathCharType(c);
+ typeMap = pathStateMachine[mode];
+ transition = typeMap[type] || typeMap['else'] || ERROR;
- if (token.repeat) {
- capture += '(?:' + prefix + capture + ')*';
- }
+ if (transition === ERROR) {
+ return // parse error
+ }
- if (token.optional) {
- if (!token.partial) {
- capture = '(?:' + prefix + '(' + capture + '))?';
- } else {
- capture = prefix + '(' + capture + ')?';
- }
- } else {
- capture = prefix + '(' + capture + ')';
+ mode = transition[0];
+ action = actions[transition[1]];
+ if (action) {
+ newChar = transition[2];
+ newChar = newChar === undefined
+ ? c
+ : newChar;
+ if (action() === false) {
+ return
}
+ }
- route += capture;
+ if (mode === AFTER_PATH) {
+ return keys
}
}
+}
- var delimiter = escapeString(options.delimiter || '/');
- var endsWithDelimiter = route.slice(-delimiter.length) === delimiter;
- // In non-strict mode we allow a slash at the end of match. If the path to
- // match already ends with a slash, we remove it for consistency. The slash
- // is valid at the end of a path match, not in the middle. This is important
- // in non-ending mode, where "/test/" shouldn't match "/test//route".
- if (!strict) {
- route = (endsWithDelimiter ? route.slice(0, -delimiter.length) : route) + '(?:' + delimiter + '(?=$))?';
- }
- if (end) {
- route += '$';
+
+
+function empty (target) {
+ /* istanbul ignore else */
+ if (Array.isArray(target)) {
+ return target.length === 0
} else {
- // In non-ending mode, we need the capturing groups to match as much as
- // possible by using a positive lookahead to the end or next path segment.
- route += strict && endsWithDelimiter ? '' : '(?=' + delimiter + '|$)';
+ return false
}
-
- return attachKeys(new RegExp('^' + route, flags(options)), keys)
}
+var I18nPath = function I18nPath () {
+ this._cache = Object.create(null);
+};
+
/**
- * Normalize the given path string, returning a regular expression.
- *
- * An empty array can be passed in for the keys, which will hold the
- * placeholder key descriptions. For example, using `/user/:id`, `keys` will
- * contain `[{ name: 'id', delimiter: '/', optional: false, repeat: false }]`.
- *
- * @param {(string|RegExp|Array)} path
- * @param {(Array|Object)=} keys
- * @param {Object=} options
- * @return {!RegExp}
+ * External parse that check for a cache hit first
*/
-function pathToRegexp (path, keys, options) {
- if (!index$1(keys)) {
- options = /** @type {!Object} */ (keys || options);
- keys = [];
+I18nPath.prototype.parsePath = function parsePath (path) {
+ var hit = this._cache[path];
+ if (!hit) {
+ hit = parse$1(path);
+ if (hit) {
+ this._cache[path] = hit;
+ }
}
+ return hit || []
+};
- options = options || {};
+/**
+ * Get path value from path string
+ */
+I18nPath.prototype.getPathValue = function getPathValue (obj, path) {
+ if (!isObject(obj)) { return null }
- if (path instanceof RegExp) {
- return regexpToRegexp(path, /** @type {!Array} */ (keys))
- }
+ var paths = this.parsePath(path);
+ if (empty(paths)) {
+ return null
+ } else {
+ var length = paths.length;
+ var ret = null;
+ var last = obj;
+ var i = 0;
+ while (i < length) {
+ var value = last[paths[i]];
+ if (value === undefined) {
+ last = null;
+ break
+ }
+ last = value;
+ i++;
+ }
- if (index$1(path)) {
- return arrayToRegexp(/** @type {!Array} */ (path), /** @type {!Array} */ (keys), options)
+ ret = last;
+ return ret
}
-
- return stringToRegexp(/** @type {string} */ (path), /** @type {!Array} */ (keys), options)
-}
-
-index.parse = parse_1;
-index.compile = compile_1;
-index.tokensToFunction = tokensToFunction_1;
-index.tokensToRegExp = tokensToRegExp_1;
+};
/* */
-var regexpCompileCache = Object.create(null);
+var VueI18n = function VueI18n (options) {
+ var this$1 = this;
+ if ( options === void 0 ) options = {};
-function fillParams (
- path,
- params,
- routeMsg
-) {
- try {
- var filler =
- regexpCompileCache[path] ||
- (regexpCompileCache[path] = index.compile(path));
- return filler(params || {}, { pretty: true })
- } catch (e) {
- if (true) {
- warn(false, ("missing param for " + routeMsg + ": " + (e.message)));
- }
- return ''
- }
-}
+ var locale = options.locale || 'en-US';
+ var fallbackLocale = options.fallbackLocale || 'en-US';
+ var messages = options.messages || {};
+ var dateTimeFormats = options.dateTimeFormats || {};
+ var numberFormats = options.numberFormats || {};
-/* */
+ this._vm = null;
+ this._formatter = options.formatter || new BaseFormatter();
+ this._missing = options.missing || null;
+ this._root = options.root || null;
+ this._sync = options.sync === undefined ? true : !!options.sync;
+ this._fallbackRoot = options.fallbackRoot === undefined
+ ? true
+ : !!options.fallbackRoot;
+ this._silentTranslationWarn = options.silentTranslationWarn === undefined
+ ? false
+ : !!options.silentTranslationWarn;
+ this._dateTimeFormatters = {};
+ this._numberFormatters = {};
+ this._path = new I18nPath();
+ this._dataListeners = [];
-function createRouteMap (
- routes,
- oldPathList,
- oldPathMap,
- oldNameMap
-) {
- // the path list is used to control path matching priority
- var pathList = oldPathList || [];
- var pathMap = oldPathMap || Object.create(null);
- var nameMap = oldNameMap || Object.create(null);
+ this._exist = function (message, key) {
+ if (!message || !key) { return false }
+ return !isNull(this$1._path.getPathValue(message, key))
+ };
- routes.forEach(function (route) {
- addRouteRecord(pathList, pathMap, nameMap, route);
+ this._initVM({
+ locale: locale,
+ fallbackLocale: fallbackLocale,
+ messages: messages,
+ dateTimeFormats: dateTimeFormats,
+ numberFormats: numberFormats
});
+};
- // ensure wildcard routes are always at the end
- for (var i = 0, l = pathList.length; i < l; i++) {
- if (pathList[i] === '*') {
- pathList.push(pathList.splice(i, 1)[0]);
- l--;
- i--;
+var prototypeAccessors = { vm: {},messages: {},dateTimeFormats: {},numberFormats: {},locale: {},fallbackLocale: {},missing: {},formatter: {},silentTranslationWarn: {} };
+
+VueI18n.prototype._initVM = function _initVM (data) {
+ var silent = Vue.config.silent;
+ Vue.config.silent = true;
+ this._vm = new Vue({ data: data });
+ Vue.config.silent = silent;
+};
+
+VueI18n.prototype.subscribeDataChanging = function subscribeDataChanging (vm) {
+ this._dataListeners.push(vm);
+};
+
+VueI18n.prototype.unsubscribeDataChanging = function unsubscribeDataChanging (vm) {
+ remove(this._dataListeners, vm);
+};
+
+VueI18n.prototype.watchI18nData = function watchI18nData () {
+ var self = this;
+ return this._vm.$watch('$data', function () {
+ var i = self._dataListeners.length;
+ while (i--) {
+ Vue.nextTick(function () {
+ self._dataListeners[i] && self._dataListeners[i].$forceUpdate();
+ });
}
- }
+ }, { deep: true })
+};
- return {
- pathList: pathList,
- pathMap: pathMap,
- nameMap: nameMap
- }
-}
+VueI18n.prototype.watchLocale = function watchLocale () {
+ /* istanbul ignore if */
+ if (!this._sync || !this._root) { return null }
+ var target = this._vm;
+ return this._root.vm.$watch('locale', function (val) {
+ target.$set(target, 'locale', val);
+ target.$forceUpdate();
+ }, { immediate: true })
+};
-function addRouteRecord (
- pathList,
- pathMap,
- nameMap,
- route,
- parent,
- matchAs
-) {
- var path = route.path;
- var name = route.name;
- if (true) {
- assert(path != null, "\"path\" is required in a route configuration.");
- assert(
- typeof route.component !== 'string',
- "route config \"component\" for path: " + (String(path || name)) + " cannot be a " +
- "string id. Use an actual component instead."
- );
- }
+prototypeAccessors.vm.get = function () { return this._vm };
- var normalizedPath = normalizePath(path, parent);
- var pathToRegexpOptions = route.pathToRegexpOptions || {};
+prototypeAccessors.messages.get = function () { return looseClone(this._getMessages()) };
+prototypeAccessors.dateTimeFormats.get = function () { return looseClone(this._getDateTimeFormats()) };
+prototypeAccessors.numberFormats.get = function () { return looseClone(this._getNumberFormats()) };
- if (typeof route.caseSensitive === 'boolean') {
- pathToRegexpOptions.sensitive = route.caseSensitive;
- }
+prototypeAccessors.locale.get = function () { return this._vm.locale };
+prototypeAccessors.locale.set = function (locale) {
+ this._vm.$set(this._vm, 'locale', locale);
+};
- var record = {
- path: normalizedPath,
- regex: compileRouteRegex(normalizedPath, pathToRegexpOptions),
- components: route.components || { default: route.component },
- instances: {},
- name: name,
- parent: parent,
- matchAs: matchAs,
- redirect: route.redirect,
- beforeEnter: route.beforeEnter,
- meta: route.meta || {},
- props: route.props == null
- ? {}
- : route.components
- ? route.props
- : { default: route.props }
- };
+prototypeAccessors.fallbackLocale.get = function () { return this._vm.fallbackLocale };
+prototypeAccessors.fallbackLocale.set = function (locale) {
+ this._vm.$set(this._vm, 'fallbackLocale', locale);
+};
- if (route.children) {
- // Warn if route is named, does not redirect and has a default child route.
- // If users navigate to this route by name, the default child will
- // not be rendered (GH Issue #629)
- if (true) {
- if (route.name && !route.redirect && route.children.some(function (child) { return /^\/?$/.test(child.path); })) {
- warn(
- false,
- "Named Route '" + (route.name) + "' has a default child route. " +
- "When navigating to this named route (:to=\"{name: '" + (route.name) + "'\"), " +
- "the default child route will not be rendered. Remove the name from " +
- "this route and use the name of the default child route for named " +
- "links instead."
- );
- }
- }
- route.children.forEach(function (child) {
- var childMatchAs = matchAs
- ? cleanPath((matchAs + "/" + (child.path)))
- : undefined;
- addRouteRecord(pathList, pathMap, nameMap, child, record, childMatchAs);
- });
- }
+prototypeAccessors.missing.get = function () { return this._missing };
+prototypeAccessors.missing.set = function (handler) { this._missing = handler; };
- if (route.alias !== undefined) {
- var aliases = Array.isArray(route.alias)
- ? route.alias
- : [route.alias];
+prototypeAccessors.formatter.get = function () { return this._formatter };
+prototypeAccessors.formatter.set = function (formatter) { this._formatter = formatter; };
- aliases.forEach(function (alias) {
- var aliasRoute = {
- path: alias,
- children: route.children
- };
- addRouteRecord(
- pathList,
- pathMap,
- nameMap,
- aliasRoute,
- parent,
- record.path || '/' // matchAs
- );
- });
- }
+prototypeAccessors.silentTranslationWarn.get = function () { return this._silentTranslationWarn };
+prototypeAccessors.silentTranslationWarn.set = function (silent) { this._silentTranslationWarn = silent; };
- if (!pathMap[record.path]) {
- pathList.push(record.path);
- pathMap[record.path] = record;
- }
+VueI18n.prototype._getMessages = function _getMessages () { return this._vm.messages };
+VueI18n.prototype._getDateTimeFormats = function _getDateTimeFormats () { return this._vm.dateTimeFormats };
+VueI18n.prototype._getNumberFormats = function _getNumberFormats () { return this._vm.numberFormats };
- if (name) {
- if (!nameMap[name]) {
- nameMap[name] = record;
- } else if ("development" !== 'production' && !matchAs) {
+VueI18n.prototype._warnDefault = function _warnDefault (locale, key, result, vm) {
+ if (!isNull(result)) { return result }
+ if (this.missing) {
+ this.missing.apply(null, [locale, key, vm]);
+ } else {
+ if ("development" !== 'production' && !this._silentTranslationWarn) {
warn(
- false,
- "Duplicate named routes definition: " +
- "{ name: \"" + name + "\", path: \"" + (record.path) + "\" }"
+ "Cannot translate the value of keypath '" + key + "'. " +
+ 'Use the value of keypath as default.'
);
}
}
-}
-
-function compileRouteRegex (path, pathToRegexpOptions) {
- var regex = index(path, [], pathToRegexpOptions);
- if (true) {
- var keys = {};
- regex.keys.forEach(function (key) {
- warn(!keys[key.name], ("Duplicate param keys in route with path: \"" + path + "\""));
- keys[key.name] = true;
- });
- }
- return regex
-}
+ return key
+};
-function normalizePath (path, parent) {
- path = path.replace(/\/$/, '');
- if (path[0] === '/') { return path }
- if (parent == null) { return path }
- return cleanPath(((parent.path) + "/" + path))
-}
+VueI18n.prototype._isFallbackRoot = function _isFallbackRoot (val) {
+ return !val && !isNull(this._root) && this._fallbackRoot
+};
-/* */
+VueI18n.prototype._interpolate = function _interpolate (
+ locale,
+ message,
+ key,
+ host,
+ interpolateMode,
+ values
+) {
+ if (!message) { return null }
+ var pathRet = this._path.getPathValue(message, key);
+ if (Array.isArray(pathRet)) { return pathRet }
-function normalizeLocation (
- raw,
- current,
- append,
- router
-) {
- var next = typeof raw === 'string' ? { path: raw } : raw;
- // named target
- if (next.name || next._normalized) {
- return next
+ var ret;
+ if (isNull(pathRet)) {
+ /* istanbul ignore else */
+ if (isPlainObject(message)) {
+ ret = message[key];
+ if (typeof ret !== 'string') {
+ if ("development" !== 'production' && !this._silentTranslationWarn) {
+ warn(("Value of key '" + key + "' is not a string!"));
+ }
+ return null
+ }
+ } else {
+ return null
+ }
+ } else {
+ /* istanbul ignore else */
+ if (typeof pathRet === 'string') {
+ ret = pathRet;
+ } else {
+ if ("development" !== 'production' && !this._silentTranslationWarn) {
+ warn(("Value of key '" + key + "' is not a string!"));
+ }
+ return null
+ }
}
- // relative params
- if (!next.path && next.params && current) {
- next = assign({}, next);
- next._normalized = true;
- var params = assign(assign({}, current.params), next.params);
- if (current.name) {
- next.name = current.name;
- next.params = params;
- } else if (current.matched.length) {
- var rawPath = current.matched[current.matched.length - 1].path;
- next.path = fillParams(rawPath, params, ("path " + (current.path)));
- } else if (true) {
- warn(false, "relative params navigation requires a current route.");
- }
- return next
+ // Check for the existance of links within the translated string
+ if (ret.indexOf('@:') >= 0) {
+ ret = this._link(locale, message, ret, host, interpolateMode, values);
}
- var parsedPath = parsePath(next.path || '');
- var basePath = (current && current.path) || '/';
- var path = parsedPath.path
- ? resolvePath(parsedPath.path, basePath, append || next.append)
- : basePath;
+ return !values ? ret : this._render(ret, interpolateMode, values)
+};
- var query = resolveQuery(
- parsedPath.query,
- next.query,
- router && router.options.parseQuery
- );
+VueI18n.prototype._link = function _link (
+ locale,
+ message,
+ str,
+ host,
+ interpolateMode,
+ values
+) {
+ var this$1 = this;
- var hash = next.hash || parsedPath.hash;
- if (hash && hash.charAt(0) !== '#') {
- hash = "#" + hash;
- }
+ var ret = str;
- return {
- _normalized: true,
- path: path,
- query: query,
- hash: hash
- }
-}
+ // Match all the links within the local
+ // We are going to replace each of
+ // them with its translation
+ var matches = ret.match(/(@:[\w\-_|.]+)/g);
+ for (var idx in matches) {
+ // ie compatible: filter custom array
+ // prototype method
+ if (!matches.hasOwnProperty(idx)) {
+ continue
+ }
+ var link = matches[idx];
+ // Remove the leading @:
+ var linkPlaceholder = link.substr(2);
+ // Translate the link
+ var translated = this$1._interpolate(
+ locale, message, linkPlaceholder, host,
+ interpolateMode === 'raw' ? 'string' : interpolateMode,
+ interpolateMode === 'raw' ? undefined : values
+ );
-function assign (a, b) {
- for (var key in b) {
- a[key] = b[key];
+ if (this$1._isFallbackRoot(translated)) {
+ if ("development" !== 'production' && !this$1._silentTranslationWarn) {
+ warn(("Fall back to translate the link placeholder '" + linkPlaceholder + "' with root locale."));
+ }
+ /* istanbul ignore if */
+ if (!this$1._root) { throw Error('unexpected error') }
+ var root = this$1._root;
+ translated = root._translate(
+ root._getMessages(), root.locale, root.fallbackLocale,
+ linkPlaceholder, host, interpolateMode, values
+ );
+ }
+ translated = this$1._warnDefault(locale, linkPlaceholder, translated, host);
+
+ // Replace the link with the translated
+ ret = !translated ? ret : ret.replace(link, translated);
}
- return a
-}
-/* */
+ return ret
+};
+VueI18n.prototype._render = function _render (message, interpolateMode, values) {
+ var ret = this._formatter.interpolate(message, values);
+ // if interpolateMode is **not** 'string' ('row'),
+ // return the compiled data (e.g. ['foo', VNode, 'bar']) with formatter
+ return interpolateMode === 'string' ? ret.join('') : ret
+};
-function createMatcher (
- routes,
- router
+VueI18n.prototype._translate = function _translate (
+ messages,
+ locale,
+ fallback,
+ key,
+ host,
+ interpolateMode,
+ args
) {
- var ref = createRouteMap(routes);
- var pathList = ref.pathList;
- var pathMap = ref.pathMap;
- var nameMap = ref.nameMap;
+ var res =
+ this._interpolate(locale, messages[locale], key, host, interpolateMode, args);
+ if (!isNull(res)) { return res }
- function addRoutes (routes) {
- createRouteMap(routes, pathList, pathMap, nameMap);
+ res = this._interpolate(fallback, messages[fallback], key, host, interpolateMode, args);
+ if (!isNull(res)) {
+ if ("development" !== 'production' && !this._silentTranslationWarn) {
+ warn(("Fall back to translate the keypath '" + key + "' with '" + fallback + "' locale."));
+ }
+ return res
+ } else {
+ return null
}
+};
- function match (
- raw,
- currentRoute,
- redirectedFrom
- ) {
- var location = normalizeLocation(raw, currentRoute, false, router);
- var name = location.name;
-
- if (name) {
- var record = nameMap[name];
- if (true) {
- warn(record, ("Route with name '" + name + "' does not exist"));
- }
- if (!record) { return _createRoute(null, location) }
- var paramNames = record.regex.keys
- .filter(function (key) { return !key.optional; })
- .map(function (key) { return key.name; });
+VueI18n.prototype._t = function _t (key, _locale, messages, host) {
+ var values = [], len = arguments.length - 4;
+ while ( len-- > 0 ) values[ len ] = arguments[ len + 4 ];
- if (typeof location.params !== 'object') {
- location.params = {};
- }
+ if (!key) { return '' }
- if (currentRoute && typeof currentRoute.params === 'object') {
- for (var key in currentRoute.params) {
- if (!(key in location.params) && paramNames.indexOf(key) > -1) {
- location.params[key] = currentRoute.params[key];
- }
- }
- }
+ var parsedArgs = parseArgs.apply(void 0, values);
+ var locale = parsedArgs.locale || _locale;
- if (record) {
- location.path = fillParams(record.path, location.params, ("named route \"" + name + "\""));
- return _createRoute(record, location, redirectedFrom)
- }
- } else if (location.path) {
- location.params = {};
- for (var i = 0; i < pathList.length; i++) {
- var path = pathList[i];
- var record$1 = pathMap[path];
- if (matchRoute(record$1.regex, location.path, location.params)) {
- return _createRoute(record$1, location, redirectedFrom)
- }
- }
+ var ret = this._translate(
+ messages, locale, this.fallbackLocale, key,
+ host, 'string', parsedArgs.params
+ );
+ if (this._isFallbackRoot(ret)) {
+ if ("development" !== 'production' && !this._silentTranslationWarn) {
+ warn(("Fall back to translate the keypath '" + key + "' with root locale."));
}
- // no match
- return _createRoute(null, location)
+ /* istanbul ignore if */
+ if (!this._root) { throw Error('unexpected error') }
+ return (ref = this._root).t.apply(ref, [ key ].concat( values ))
+ } else {
+ return this._warnDefault(locale, key, ret, host)
}
+ var ref;
+};
- function redirect (
- record,
- location
- ) {
- var originalRedirect = record.redirect;
- var redirect = typeof originalRedirect === 'function'
- ? originalRedirect(createRoute(record, location, null, router))
- : originalRedirect;
+VueI18n.prototype.t = function t (key) {
+ var values = [], len = arguments.length - 1;
+ while ( len-- > 0 ) values[ len ] = arguments[ len + 1 ];
- if (typeof redirect === 'string') {
- redirect = { path: redirect };
- }
+ return (ref = this)._t.apply(ref, [ key, this.locale, this._getMessages(), null ].concat( values ))
+ var ref;
+};
- if (!redirect || typeof redirect !== 'object') {
- if (true) {
- warn(
- false, ("invalid redirect option: " + (JSON.stringify(redirect)))
- );
- }
- return _createRoute(null, location)
- }
-
- var re = redirect;
- var name = re.name;
- var path = re.path;
- var query = location.query;
- var hash = location.hash;
- var params = location.params;
- query = re.hasOwnProperty('query') ? re.query : query;
- hash = re.hasOwnProperty('hash') ? re.hash : hash;
- params = re.hasOwnProperty('params') ? re.params : params;
-
- if (name) {
- // resolved named direct
- var targetRecord = nameMap[name];
- if (true) {
- assert(targetRecord, ("redirect failed: named route \"" + name + "\" not found."));
- }
- return match({
- _normalized: true,
- name: name,
- query: query,
- hash: hash,
- params: params
- }, undefined, location)
- } else if (path) {
- // 1. resolve relative redirect
- var rawPath = resolveRecordPath(path, record);
- // 2. resolve params
- var resolvedPath = fillParams(rawPath, params, ("redirect route with path \"" + rawPath + "\""));
- // 3. rematch with existing query and hash
- return match({
- _normalized: true,
- path: resolvedPath,
- query: query,
- hash: hash
- }, undefined, location)
- } else {
- if (true) {
- warn(false, ("invalid redirect option: " + (JSON.stringify(redirect))));
- }
- return _createRoute(null, location)
+VueI18n.prototype._i = function _i (key, locale, messages, host, values) {
+ var ret =
+ this._translate(messages, locale, this.fallbackLocale, key, host, 'raw', values);
+ if (this._isFallbackRoot(ret)) {
+ if ("development" !== 'production' && !this._silentTranslationWarn) {
+ warn(("Fall back to interpolate the keypath '" + key + "' with root locale."));
}
+ if (!this._root) { throw Error('unexpected error') }
+ return this._root.i(key, locale, values)
+ } else {
+ return this._warnDefault(locale, key, ret, host)
}
+};
- function alias (
- record,
- location,
- matchAs
- ) {
- var aliasedPath = fillParams(matchAs, location.params, ("aliased route with path \"" + matchAs + "\""));
- var aliasedMatch = match({
- _normalized: true,
- path: aliasedPath
- });
- if (aliasedMatch) {
- var matched = aliasedMatch.matched;
- var aliasedRecord = matched[matched.length - 1];
- location.params = aliasedMatch.params;
- return _createRoute(aliasedRecord, location)
- }
- return _createRoute(null, location)
- }
+VueI18n.prototype.i = function i (key, locale, values) {
+ /* istanbul ignore if */
+ if (!key) { return '' }
- function _createRoute (
- record,
- location,
- redirectedFrom
- ) {
- if (record && record.redirect) {
- return redirect(record, redirectedFrom || location)
- }
- if (record && record.matchAs) {
- return alias(record, location, record.matchAs)
- }
- return createRoute(record, location, redirectedFrom, router)
+ if (typeof locale !== 'string') {
+ locale = this.locale;
}
- return {
- match: match,
- addRoutes: addRoutes
- }
-}
+ return this._i(key, locale, this._getMessages(), null, values)
+};
-function matchRoute (
- regex,
- path,
- params
+VueI18n.prototype._tc = function _tc (
+ key,
+ _locale,
+ messages,
+ host,
+ choice
) {
- var m = path.match(regex);
+ var values = [], len = arguments.length - 5;
+ while ( len-- > 0 ) values[ len ] = arguments[ len + 5 ];
- if (!m) {
- return false
- } else if (!params) {
- return true
+ if (!key) { return '' }
+ if (choice === undefined) {
+ choice = 1;
}
+ return fetchChoice((ref = this)._t.apply(ref, [ key, _locale, messages, host ].concat( values )), choice)
+ var ref;
+};
- for (var i = 1, len = m.length; i < len; ++i) {
- var key = regex.keys[i - 1];
- var val = typeof m[i] === 'string' ? decodeURIComponent(m[i]) : m[i];
- if (key) {
- params[key.name] = val;
- }
- }
+VueI18n.prototype.tc = function tc (key, choice) {
+ var values = [], len = arguments.length - 2;
+ while ( len-- > 0 ) values[ len ] = arguments[ len + 2 ];
- return true
-}
+ return (ref = this)._tc.apply(ref, [ key, this.locale, this._getMessages(), null, choice ].concat( values ))
+ var ref;
+};
-function resolveRecordPath (path, record) {
- return resolvePath(path, record.parent ? record.parent.path : '/', true)
-}
+VueI18n.prototype._te = function _te (key, locale, messages) {
+ var args = [], len = arguments.length - 3;
+ while ( len-- > 0 ) args[ len ] = arguments[ len + 3 ];
-/* */
+ var _locale = parseArgs.apply(void 0, args).locale || locale;
+ return this._exist(messages[_locale], key)
+};
+VueI18n.prototype.te = function te (key, locale) {
+ return this._te(key, this.locale, this._getMessages(), locale)
+};
-var positionStore = Object.create(null);
+VueI18n.prototype.getLocaleMessage = function getLocaleMessage (locale) {
+ return looseClone(this._vm.messages[locale] || {})
+};
-function setupScroll () {
- window.addEventListener('popstate', function (e) {
- saveScrollPosition();
- if (e.state && e.state.key) {
- setStateKey(e.state.key);
- }
- });
-}
+VueI18n.prototype.setLocaleMessage = function setLocaleMessage (locale, message) {
+ this._vm.messages[locale] = message;
+};
-function handleScroll (
- router,
- to,
- from,
- isPop
+ VueI18n.prototype.mergeLocaleMessage = function mergeLocaleMessage (locale, message) {
+ this._vm.messages[locale] = Vue.util.extend(this._vm.messages[locale] || {}, message);
+};
+
+VueI18n.prototype.getDateTimeFormat = function getDateTimeFormat (locale) {
+ return looseClone(this._vm.dateTimeFormats[locale] || {})
+};
+
+VueI18n.prototype.setDateTimeFormat = function setDateTimeFormat (locale, format) {
+ this._vm.dateTimeFormats[locale] = format;
+};
+
+VueI18n.prototype.mergeDateTimeFormat = function mergeDateTimeFormat (locale, format) {
+ this._vm.dateTimeFormats[locale] = Vue.util.extend(this._vm.dateTimeFormats[locale] || {}, format);
+};
+
+VueI18n.prototype._localizeDateTime = function _localizeDateTime (
+ value,
+ locale,
+ fallback,
+ dateTimeFormats,
+ key
) {
- if (!router.app) {
- return
+ var _locale = locale;
+ var formats = dateTimeFormats[_locale];
+
+ // fallback locale
+ if (isNull(formats) || isNull(formats[key])) {
+ if (true) {
+ warn(("Fall back to '" + fallback + "' datetime formats from '" + locale + " datetime formats."));
+ }
+ _locale = fallback;
+ formats = dateTimeFormats[_locale];
}
- var behavior = router.options.scrollBehavior;
- if (!behavior) {
- return
+ if (isNull(formats) || isNull(formats[key])) {
+ return null
+ } else {
+ var format = formats[key];
+ var id = _locale + "__" + key;
+ var formatter = this._dateTimeFormatters[id];
+ if (!formatter) {
+ formatter = this._dateTimeFormatters[id] = new Intl.DateTimeFormat(_locale, format);
+ }
+ return formatter.format(value)
}
+};
- if (true) {
- assert(typeof behavior === 'function', "scrollBehavior must be a function");
+VueI18n.prototype._d = function _d (value, locale, key) {
+ /* istanbul ignore if */
+ if ("development" !== 'production' && !VueI18n.availabilities.dateTimeFormat) {
+ warn('Cannot format a Date value due to not support Intl.DateTimeFormat.');
+ return ''
}
- // wait until re-render finishes before scrolling
- router.app.$nextTick(function () {
- var position = getScrollPosition();
- var shouldScroll = behavior(to, from, isPop ? position : null);
- if (!shouldScroll) {
- return
+ if (!key) {
+ return new Intl.DateTimeFormat(locale).format(value)
+ }
+
+ var ret =
+ this._localizeDateTime(value, locale, this.fallbackLocale, this._getDateTimeFormats(), key);
+ if (this._isFallbackRoot(ret)) {
+ if (true) {
+ warn(("Fall back to datetime localization of root: key '" + key + "' ."));
}
- var isObject = typeof shouldScroll === 'object';
- if (isObject && typeof shouldScroll.selector === 'string') {
- var el = document.querySelector(shouldScroll.selector);
- if (el) {
- var offset = shouldScroll.offset && typeof shouldScroll.offset === 'object' ? shouldScroll.offset : {};
- offset = normalizeOffset(offset);
- position = getElementPosition(el, offset);
- } else if (isValidPosition(shouldScroll)) {
- position = normalizePosition(shouldScroll);
+ /* istanbul ignore if */
+ if (!this._root) { throw Error('unexpected error') }
+ return this._root.d(value, key, locale)
+ } else {
+ return ret || ''
+ }
+};
+
+VueI18n.prototype.d = function d (value) {
+ var args = [], len = arguments.length - 1;
+ while ( len-- > 0 ) args[ len ] = arguments[ len + 1 ];
+
+ var locale = this.locale;
+ var key = null;
+
+ if (args.length === 1) {
+ if (typeof args[0] === 'string') {
+ key = args[0];
+ } else if (isObject(args[0])) {
+ if (args[0].locale) {
+ locale = args[0].locale;
+ }
+ if (args[0].key) {
+ key = args[0].key;
}
- } else if (isObject && isValidPosition(shouldScroll)) {
- position = normalizePosition(shouldScroll);
}
-
- if (position) {
- window.scrollTo(position.x, position.y);
+ } else if (args.length === 2) {
+ if (typeof args[0] === 'string') {
+ key = args[0];
+ }
+ if (typeof args[1] === 'string') {
+ locale = args[1];
}
- });
-}
-
-function saveScrollPosition () {
- var key = getStateKey();
- if (key) {
- positionStore[key] = {
- x: window.pageXOffset,
- y: window.pageYOffset
- };
}
-}
-function getScrollPosition () {
- var key = getStateKey();
- if (key) {
- return positionStore[key]
- }
-}
+ return this._d(value, locale, key)
+};
-function getElementPosition (el, offset) {
- var docEl = document.documentElement;
- var docRect = docEl.getBoundingClientRect();
- var elRect = el.getBoundingClientRect();
- return {
- x: elRect.left - docRect.left - offset.x,
- y: elRect.top - docRect.top - offset.y
+VueI18n.prototype.getNumberFormat = function getNumberFormat (locale) {
+ return looseClone(this._vm.numberFormats[locale] || {})
+};
+
+VueI18n.prototype.setNumberFormat = function setNumberFormat (locale, format) {
+ this._vm.numberFormats[locale] = format;
+};
+
+VueI18n.prototype.mergeNumberFormat = function mergeNumberFormat (locale, format) {
+ this._vm.numberFormats[locale] = Vue.util.extend(this._vm.numberFormats[locale] || {}, format);
+};
+
+VueI18n.prototype._localizeNumber = function _localizeNumber (
+ value,
+ locale,
+ fallback,
+ numberFormats,
+ key
+) {
+ var _locale = locale;
+ var formats = numberFormats[_locale];
+
+ // fallback locale
+ if (isNull(formats) || isNull(formats[key])) {
+ if (true) {
+ warn(("Fall back to '" + fallback + "' number formats from '" + locale + " number formats."));
+ }
+ _locale = fallback;
+ formats = numberFormats[_locale];
}
-}
-function isValidPosition (obj) {
- return isNumber(obj.x) || isNumber(obj.y)
-}
+ if (isNull(formats) || isNull(formats[key])) {
+ return null
+ } else {
+ var format = formats[key];
+ var id = _locale + "__" + key;
+ var formatter = this._numberFormatters[id];
+ if (!formatter) {
+ formatter = this._numberFormatters[id] = new Intl.NumberFormat(_locale, format);
+ }
+ return formatter.format(value)
+ }
+};
-function normalizePosition (obj) {
- return {
- x: isNumber(obj.x) ? obj.x : window.pageXOffset,
- y: isNumber(obj.y) ? obj.y : window.pageYOffset
+VueI18n.prototype._n = function _n (value, locale, key) {
+ /* istanbul ignore if */
+ if ("development" !== 'production' && !VueI18n.availabilities.numberFormat) {
+ warn('Cannot format a Date value due to not support Intl.NumberFormat.');
+ return ''
}
-}
-function normalizeOffset (obj) {
- return {
- x: isNumber(obj.x) ? obj.x : 0,
- y: isNumber(obj.y) ? obj.y : 0
+ if (!key) {
+ return new Intl.NumberFormat(locale).format(value)
}
-}
-function isNumber (v) {
- return typeof v === 'number'
-}
+ var ret =
+ this._localizeNumber(value, locale, this.fallbackLocale, this._getNumberFormats(), key);
+ if (this._isFallbackRoot(ret)) {
+ if (true) {
+ warn(("Fall back to number localization of root: key '" + key + "' ."));
+ }
+ /* istanbul ignore if */
+ if (!this._root) { throw Error('unexpected error') }
+ return this._root.n(value, key, locale)
+ } else {
+ return ret || ''
+ }
+};
-/* */
+VueI18n.prototype.n = function n (value) {
+ var args = [], len = arguments.length - 1;
+ while ( len-- > 0 ) args[ len ] = arguments[ len + 1 ];
-var supportsPushState = inBrowser && (function () {
- var ua = window.navigator.userAgent;
+ var locale = this.locale;
+ var key = null;
- if (
- (ua.indexOf('Android 2.') !== -1 || ua.indexOf('Android 4.0') !== -1) &&
- ua.indexOf('Mobile Safari') !== -1 &&
- ua.indexOf('Chrome') === -1 &&
- ua.indexOf('Windows Phone') === -1
- ) {
- return false
+ if (args.length === 1) {
+ if (typeof args[0] === 'string') {
+ key = args[0];
+ } else if (isObject(args[0])) {
+ if (args[0].locale) {
+ locale = args[0].locale;
+ }
+ if (args[0].key) {
+ key = args[0].key;
+ }
+ }
+ } else if (args.length === 2) {
+ if (typeof args[0] === 'string') {
+ key = args[0];
+ }
+ if (typeof args[1] === 'string') {
+ locale = args[1];
+ }
}
- return window.history && 'pushState' in window.history
-})();
+ return this._n(value, locale, key)
+};
-// use User Timing api (if present) for more accurate key precision
-var Time = inBrowser && window.performance && window.performance.now
- ? window.performance
- : Date;
+Object.defineProperties( VueI18n.prototype, prototypeAccessors );
-var _key = genKey();
+VueI18n.availabilities = {
+ dateTimeFormat: canUseDateTimeFormat,
+ numberFormat: canUseNumberFormat
+};
+VueI18n.install = install;
+VueI18n.version = '7.2.0';
-function genKey () {
- return Time.now().toFixed(3)
+/* istanbul ignore if */
+if (typeof window !== 'undefined' && window.Vue) {
+ window.Vue.use(VueI18n);
}
-function getStateKey () {
- return _key
-}
+/* harmony default export */ __webpack_exports__["default"] = (VueI18n);
-function setStateKey (key) {
- _key = key;
-}
-function pushState (url, replace) {
- saveScrollPosition();
- // try...catch the pushState call to get around Safari
- // DOM Exception 18 where it limits to 100 pushState calls
- var history = window.history;
- try {
- if (replace) {
- history.replaceState({ key: _key }, '', url);
- } else {
- _key = genKey();
- history.pushState({ key: _key }, '', url);
- }
- } catch (e) {
- window.location[replace ? 'replace' : 'assign'](url);
+/***/ }),
+/* 40 */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
+/**
+ * vue-router v2.7.0
+ * (c) 2017 Evan You
+ * @license MIT
+ */
+/* */
+
+function assert (condition, message) {
+ if (!condition) {
+ throw new Error(("[vue-router] " + message))
}
}
-function replaceState (url) {
- pushState(url, true);
+function warn (condition, message) {
+ if ("development" !== 'production' && !condition) {
+ typeof console !== 'undefined' && console.warn(("[vue-router] " + message));
+ }
}
-/* */
+function isError (err) {
+ return Object.prototype.toString.call(err).indexOf('Error') > -1
+}
-function runQueue (queue, fn, cb) {
- var step = function (index) {
- if (index >= queue.length) {
- cb();
- } else {
- if (queue[index]) {
- fn(queue[index], function () {
- step(index + 1);
- });
- } else {
- step(index + 1);
- }
+var View = {
+ name: 'router-view',
+ functional: true,
+ props: {
+ name: {
+ type: String,
+ default: 'default'
}
- };
- step(0);
-}
+ },
+ render: function render (_, ref) {
+ var props = ref.props;
+ var children = ref.children;
+ var parent = ref.parent;
+ var data = ref.data;
-/* */
+ data.routerView = true;
-function resolveAsyncComponents (matched) {
- return function (to, from, next) {
- var hasAsync = false;
- var pending = 0;
- var error = null;
+ // directly use parent context's createElement() function
+ // so that components rendered by router-view can resolve named slots
+ var h = parent.$createElement;
+ var name = props.name;
+ var route = parent.$route;
+ var cache = parent._routerViewCache || (parent._routerViewCache = {});
- flatMapComponents(matched, function (def, _, match, key) {
- // if it's a function and doesn't have cid attached,
- // assume it's an async component resolve function.
- // we are not using Vue's default async resolving mechanism because
- // we want to halt the navigation until the incoming component has been
- // resolved.
- if (typeof def === 'function' && def.cid === undefined) {
- hasAsync = true;
- pending++;
+ // determine current view depth, also check to see if the tree
+ // has been toggled inactive but kept-alive.
+ var depth = 0;
+ var inactive = false;
+ while (parent && parent._routerRoot !== parent) {
+ if (parent.$vnode && parent.$vnode.data.routerView) {
+ depth++;
+ }
+ if (parent._inactive) {
+ inactive = true;
+ }
+ parent = parent.$parent;
+ }
+ data.routerViewDepth = depth;
- var resolve = once(function (resolvedDef) {
- if (resolvedDef.__esModule && resolvedDef.default) {
- resolvedDef = resolvedDef.default;
- }
- // save resolved on async factory in case it's used elsewhere
- def.resolved = typeof resolvedDef === 'function'
- ? resolvedDef
- : _Vue.extend(resolvedDef);
- match.components[key] = resolvedDef;
- pending--;
- if (pending <= 0) {
- next();
- }
- });
+ // render previous view if the tree is inactive and kept-alive
+ if (inactive) {
+ return h(cache[name], data, children)
+ }
- var reject = once(function (reason) {
- var msg = "Failed to resolve async component " + key + ": " + reason;
- "development" !== 'production' && warn(false, msg);
- if (!error) {
- error = isError(reason)
- ? reason
- : new Error(msg);
- next(error);
- }
- });
+ var matched = route.matched[depth];
+ // render empty node if no matched route
+ if (!matched) {
+ cache[name] = null;
+ return h()
+ }
- var res;
- try {
- res = def(resolve, reject);
- } catch (e) {
- reject(e);
- }
- if (res) {
- if (typeof res.then === 'function') {
- res.then(resolve, reject);
- } else {
- // new syntax in Vue 2.3
- var comp = res.component;
- if (comp && typeof comp.then === 'function') {
- comp.then(resolve, reject);
- }
- }
- }
- }
- });
+ var component = cache[name] = matched.components[name];
- if (!hasAsync) { next(); }
- }
-}
+ // attach instance registration hook
+ // this will be called in the instance's injected lifecycle hooks
+ data.registerRouteInstance = function (vm, val) {
+ // val could be undefined for unregistration
+ var current = matched.instances[name];
+ if (
+ (val && current !== vm) ||
+ (!val && current === vm)
+ ) {
+ matched.instances[name] = val;
+ }
+ }
-function flatMapComponents (
- matched,
- fn
-) {
- return flatten(matched.map(function (m) {
- return Object.keys(m.components).map(function (key) { return fn(
- m.components[key],
- m.instances[key],
- m, key
- ); })
- }))
-}
+ // also regiseter instance in prepatch hook
+ // in case the same component instance is reused across different routes
+ ;(data.hook || (data.hook = {})).prepatch = function (_, vnode) {
+ matched.instances[name] = vnode.componentInstance;
+ };
-function flatten (arr) {
- return Array.prototype.concat.apply([], arr)
-}
+ // resolve props
+ data.props = resolveProps(route, matched.props && matched.props[name]);
-// in Webpack 2, require.ensure now also returns a Promise
-// so the resolve/reject functions may get called an extra time
-// if the user uses an arrow function shorthand that happens to
-// return that Promise.
-function once (fn) {
- var called = false;
- return function () {
- var args = [], len = arguments.length;
- while ( len-- ) args[ len ] = arguments[ len ];
+ return h(component, data, children)
+ }
+};
- if (called) { return }
- called = true;
- return fn.apply(this, args)
+function resolveProps (route, config) {
+ switch (typeof config) {
+ case 'undefined':
+ return
+ case 'object':
+ return config
+ case 'function':
+ return config(route)
+ case 'boolean':
+ return config ? route.params : undefined
+ default:
+ if (true) {
+ warn(
+ false,
+ "props in \"" + (route.path) + "\" is a " + (typeof config) + ", " +
+ "expecting an object, function or boolean."
+ );
+ }
}
}
/* */
-var History = function History (router, base) {
- this.router = router;
- this.base = normalizeBase(base);
- // start with a route object that stands for "nowhere"
- this.current = START;
- this.pending = null;
- this.ready = false;
- this.readyCbs = [];
- this.readyErrorCbs = [];
- this.errorCbs = [];
-};
+var encodeReserveRE = /[!'()*]/g;
+var encodeReserveReplacer = function (c) { return '%' + c.charCodeAt(0).toString(16); };
+var commaRE = /%2C/g;
-History.prototype.listen = function listen (cb) {
- this.cb = cb;
-};
+// fixed encodeURIComponent which is more conformant to RFC3986:
+// - escapes [!'()*]
+// - preserve commas
+var encode = function (str) { return encodeURIComponent(str)
+ .replace(encodeReserveRE, encodeReserveReplacer)
+ .replace(commaRE, ','); };
-History.prototype.onReady = function onReady (cb, errorCb) {
- if (this.ready) {
- cb();
- } else {
- this.readyCbs.push(cb);
- if (errorCb) {
- this.readyErrorCbs.push(errorCb);
- }
+var decode = decodeURIComponent;
+
+function resolveQuery (
+ query,
+ extraQuery,
+ _parseQuery
+) {
+ if ( extraQuery === void 0 ) extraQuery = {};
+
+ var parse = _parseQuery || parseQuery;
+ var parsedQuery;
+ try {
+ parsedQuery = parse(query || '');
+ } catch (e) {
+ "development" !== 'production' && warn(false, e.message);
+ parsedQuery = {};
}
-};
+ for (var key in extraQuery) {
+ var val = extraQuery[key];
+ parsedQuery[key] = Array.isArray(val) ? val.slice() : val;
+ }
+ return parsedQuery
+}
-History.prototype.onError = function onError (errorCb) {
- this.errorCbs.push(errorCb);
-};
+function parseQuery (query) {
+ var res = {};
-History.prototype.transitionTo = function transitionTo (location, onComplete, onAbort) {
- var this$1 = this;
+ query = query.trim().replace(/^(\?|#|&)/, '');
- var route = this.router.match(location, this.current);
- this.confirmTransition(route, function () {
- this$1.updateRoute(route);
- onComplete && onComplete(route);
- this$1.ensureURL();
+ if (!query) {
+ return res
+ }
- // fire ready cbs once
- if (!this$1.ready) {
- this$1.ready = true;
- this$1.readyCbs.forEach(function (cb) { cb(route); });
- }
- }, function (err) {
- if (onAbort) {
- onAbort(err);
- }
- if (err && !this$1.ready) {
- this$1.ready = true;
- this$1.readyErrorCbs.forEach(function (cb) { cb(err); });
+ query.split('&').forEach(function (param) {
+ var parts = param.replace(/\+/g, ' ').split('=');
+ var key = decode(parts.shift());
+ var val = parts.length > 0
+ ? decode(parts.join('='))
+ : null;
+
+ if (res[key] === undefined) {
+ res[key] = val;
+ } else if (Array.isArray(res[key])) {
+ res[key].push(val);
+ } else {
+ res[key] = [res[key], val];
}
});
-};
-
-History.prototype.confirmTransition = function confirmTransition (route, onComplete, onAbort) {
- var this$1 = this;
- var current = this.current;
- var abort = function (err) {
- if (isError(err)) {
- if (this$1.errorCbs.length) {
- this$1.errorCbs.forEach(function (cb) { cb(err); });
- } else {
- warn(false, 'uncaught error during route navigation:');
- console.error(err);
- }
- }
- onAbort && onAbort(err);
- };
- if (
- isSameRoute(route, current) &&
- // in the case the route map has been dynamically appended to
- route.matched.length === current.matched.length
- ) {
- this.ensureURL();
- return abort()
- }
+ return res
+}
- var ref = resolveQueue(this.current.matched, route.matched);
- var updated = ref.updated;
- var deactivated = ref.deactivated;
- var activated = ref.activated;
+function stringifyQuery (obj) {
+ var res = obj ? Object.keys(obj).map(function (key) {
+ var val = obj[key];
- var queue = [].concat(
- // in-component leave guards
- extractLeaveGuards(deactivated),
- // global before hooks
- this.router.beforeHooks,
- // in-component update hooks
- extractUpdateHooks(updated),
- // in-config enter guards
- activated.map(function (m) { return m.beforeEnter; }),
- // async components
- resolveAsyncComponents(activated)
- );
+ if (val === undefined) {
+ return ''
+ }
- this.pending = route;
- var iterator = function (hook, next) {
- if (this$1.pending !== route) {
- return abort()
+ if (val === null) {
+ return encode(key)
}
- try {
- hook(route, current, function (to) {
- if (to === false || isError(to)) {
- // next(false) -> abort navigation, ensure current URL
- this$1.ensureURL(true);
- abort(to);
- } else if (
- typeof to === 'string' ||
- (typeof to === 'object' && (
- typeof to.path === 'string' ||
- typeof to.name === 'string'
- ))
- ) {
- // next('/') or next({ path: '/' }) -> redirect
- abort();
- if (typeof to === 'object' && to.replace) {
- this$1.replace(to);
- } else {
- this$1.push(to);
- }
+
+ if (Array.isArray(val)) {
+ var result = [];
+ val.forEach(function (val2) {
+ if (val2 === undefined) {
+ return
+ }
+ if (val2 === null) {
+ result.push(encode(key));
} else {
- // confirm transition and pass on the value
- next(to);
+ result.push(encode(key) + '=' + encode(val2));
}
});
- } catch (e) {
- abort(e);
+ return result.join('&')
}
- };
- runQueue(queue, iterator, function () {
- var postEnterCbs = [];
- var isValid = function () { return this$1.current === route; };
- // wait until async components are resolved before
- // extracting in-component enter guards
- var enterGuards = extractEnterGuards(activated, postEnterCbs, isValid);
- var queue = enterGuards.concat(this$1.router.resolveHooks);
- runQueue(queue, iterator, function () {
- if (this$1.pending !== route) {
- return abort()
- }
- this$1.pending = null;
- onComplete(route);
- if (this$1.router.app) {
- this$1.router.app.$nextTick(function () {
- postEnterCbs.forEach(function (cb) { cb(); });
- });
- }
- });
- });
-};
+ return encode(key) + '=' + encode(val)
+ }).filter(function (x) { return x.length > 0; }).join('&') : null;
+ return res ? ("?" + res) : ''
+}
-History.prototype.updateRoute = function updateRoute (route) {
- var prev = this.current;
- this.current = route;
- this.cb && this.cb(route);
- this.router.afterHooks.forEach(function (hook) {
- hook && hook(route, prev);
- });
-};
+/* */
-function normalizeBase (base) {
- if (!base) {
- if (inBrowser) {
- // respect tag
- var baseEl = document.querySelector('base');
- base = (baseEl && baseEl.getAttribute('href')) || '/';
- // strip full URL origin
- base = base.replace(/^https?:\/\/[^\/]+/, '');
- } else {
- base = '/';
- }
- }
- // make sure there's the starting slash
- if (base.charAt(0) !== '/') {
- base = '/' + base;
- }
- // remove trailing slash
- return base.replace(/\/$/, '')
-}
-function resolveQueue (
- current,
- next
+var trailingSlashRE = /\/?$/;
+
+function createRoute (
+ record,
+ location,
+ redirectedFrom,
+ router
) {
- var i;
- var max = Math.max(current.length, next.length);
- for (i = 0; i < max; i++) {
- if (current[i] !== next[i]) {
- break
- }
- }
- return {
- updated: next.slice(0, i),
- activated: next.slice(i),
- deactivated: current.slice(i)
+ var stringifyQuery$$1 = router && router.options.stringifyQuery;
+ var route = {
+ name: location.name || (record && record.name),
+ meta: (record && record.meta) || {},
+ path: location.path || '/',
+ hash: location.hash || '',
+ query: location.query || {},
+ params: location.params || {},
+ fullPath: getFullPath(location, stringifyQuery$$1),
+ matched: record ? formatMatch(record) : []
+ };
+ if (redirectedFrom) {
+ route.redirectedFrom = getFullPath(redirectedFrom, stringifyQuery$$1);
}
+ return Object.freeze(route)
}
-function extractGuards (
- records,
- name,
- bind,
- reverse
-) {
- var guards = flatMapComponents(records, function (def, instance, match, key) {
- var guard = extractGuard(def, name);
- if (guard) {
- return Array.isArray(guard)
- ? guard.map(function (guard) { return bind(guard, instance, match, key); })
- : bind(guard, instance, match, key)
- }
- });
- return flatten(reverse ? guards.reverse() : guards)
-}
+// the starting route that represents the initial state
+var START = createRoute(null, {
+ path: '/'
+});
-function extractGuard (
- def,
- key
-) {
- if (typeof def !== 'function') {
- // extend now so that global mixins are applied.
- def = _Vue.extend(def);
+function formatMatch (record) {
+ var res = [];
+ while (record) {
+ res.unshift(record);
+ record = record.parent;
}
- return def.options[key]
+ return res
}
-function extractLeaveGuards (deactivated) {
- return extractGuards(deactivated, 'beforeRouteLeave', bindGuard, true)
-}
+function getFullPath (
+ ref,
+ _stringifyQuery
+) {
+ var path = ref.path;
+ var query = ref.query; if ( query === void 0 ) query = {};
+ var hash = ref.hash; if ( hash === void 0 ) hash = '';
-function extractUpdateHooks (updated) {
- return extractGuards(updated, 'beforeRouteUpdate', bindGuard)
+ var stringify = _stringifyQuery || stringifyQuery;
+ return (path || '/') + stringify(query) + hash
}
-function bindGuard (guard, instance) {
- if (instance) {
- return function boundRouteGuard () {
- return guard.apply(instance, arguments)
- }
+function isSameRoute (a, b) {
+ if (b === START) {
+ return a === b
+ } else if (!b) {
+ return false
+ } else if (a.path && b.path) {
+ return (
+ a.path.replace(trailingSlashRE, '') === b.path.replace(trailingSlashRE, '') &&
+ a.hash === b.hash &&
+ isObjectEqual(a.query, b.query)
+ )
+ } else if (a.name && b.name) {
+ return (
+ a.name === b.name &&
+ a.hash === b.hash &&
+ isObjectEqual(a.query, b.query) &&
+ isObjectEqual(a.params, b.params)
+ )
+ } else {
+ return false
}
}
-function extractEnterGuards (
- activated,
- cbs,
- isValid
-) {
- return extractGuards(activated, 'beforeRouteEnter', function (guard, _, match, key) {
- return bindEnterGuard(guard, match, key, cbs, isValid)
- })
-}
+function isObjectEqual (a, b) {
+ if ( a === void 0 ) a = {};
+ if ( b === void 0 ) b = {};
-function bindEnterGuard (
- guard,
- match,
- key,
- cbs,
- isValid
-) {
- return function routeEnterGuard (to, from, next) {
- return guard(to, from, function (cb) {
- next(cb);
- if (typeof cb === 'function') {
- cbs.push(function () {
- // #750
- // if a router-view is wrapped with an out-in transition,
- // the instance may not have been registered at this time.
- // we will need to poll for registration until current route
- // is no longer valid.
- poll(cb, match.instances, key, isValid);
- });
- }
- })
+ var aKeys = Object.keys(a);
+ var bKeys = Object.keys(b);
+ if (aKeys.length !== bKeys.length) {
+ return false
}
+ return aKeys.every(function (key) {
+ var aVal = a[key];
+ var bVal = b[key];
+ // check nested equality
+ if (typeof aVal === 'object' && typeof bVal === 'object') {
+ return isObjectEqual(aVal, bVal)
+ }
+ return String(aVal) === String(bVal)
+ })
}
-function poll (
- cb, // somehow flow cannot infer this is a function
- instances,
- key,
- isValid
-) {
- if (instances[key]) {
- cb(instances[key]);
- } else if (isValid()) {
- setTimeout(function () {
- poll(cb, instances, key, isValid);
- }, 16);
+function isIncludedRoute (current, target) {
+ return (
+ current.path.replace(trailingSlashRE, '/').indexOf(
+ target.path.replace(trailingSlashRE, '/')
+ ) === 0 &&
+ (!target.hash || current.hash === target.hash) &&
+ queryIncludes(current.query, target.query)
+ )
+}
+
+function queryIncludes (current, target) {
+ for (var key in target) {
+ if (!(key in current)) {
+ return false
+ }
}
+ return true
}
/* */
+// work around weird flow bug
+var toTypes = [String, Object];
+var eventTypes = [String, Array];
-var HTML5History = (function (History$$1) {
- function HTML5History (router, base) {
+var Link = {
+ name: 'router-link',
+ props: {
+ to: {
+ type: toTypes,
+ required: true
+ },
+ tag: {
+ type: String,
+ default: 'a'
+ },
+ exact: Boolean,
+ append: Boolean,
+ replace: Boolean,
+ activeClass: String,
+ exactActiveClass: String,
+ event: {
+ type: eventTypes,
+ default: 'click'
+ }
+ },
+ render: function render (h) {
var this$1 = this;
- History$$1.call(this, router, base);
+ var router = this.$router;
+ var current = this.$route;
+ var ref = router.resolve(this.to, current, this.append);
+ var location = ref.location;
+ var route = ref.route;
+ var href = ref.href;
- var expectScroll = router.options.scrollBehavior;
+ var classes = {};
+ var globalActiveClass = router.options.linkActiveClass;
+ var globalExactActiveClass = router.options.linkExactActiveClass;
+ // Support global empty active class
+ var activeClassFallback = globalActiveClass == null
+ ? 'router-link-active'
+ : globalActiveClass;
+ var exactActiveClassFallback = globalExactActiveClass == null
+ ? 'router-link-exact-active'
+ : globalExactActiveClass;
+ var activeClass = this.activeClass == null
+ ? activeClassFallback
+ : this.activeClass;
+ var exactActiveClass = this.exactActiveClass == null
+ ? exactActiveClassFallback
+ : this.exactActiveClass;
+ var compareTarget = location.path
+ ? createRoute(null, location, null, router)
+ : route;
- if (expectScroll) {
- setupScroll();
- }
+ classes[exactActiveClass] = isSameRoute(current, compareTarget);
+ classes[activeClass] = this.exact
+ ? classes[exactActiveClass]
+ : isIncludedRoute(current, compareTarget);
- window.addEventListener('popstate', function (e) {
- var current = this$1.current;
- this$1.transitionTo(getLocation(this$1.base), function (route) {
- if (expectScroll) {
- handleScroll(router, route, current, true);
+ var handler = function (e) {
+ if (guardEvent(e)) {
+ if (this$1.replace) {
+ router.replace(location);
+ } else {
+ router.push(location);
}
- });
- });
- }
-
- if ( History$$1 ) HTML5History.__proto__ = History$$1;
- HTML5History.prototype = Object.create( History$$1 && History$$1.prototype );
- HTML5History.prototype.constructor = HTML5History;
-
- HTML5History.prototype.go = function go (n) {
- window.history.go(n);
- };
-
- HTML5History.prototype.push = function push (location, onComplete, onAbort) {
- var this$1 = this;
-
- var ref = this;
- var fromRoute = ref.current;
- this.transitionTo(location, function (route) {
- pushState(cleanPath(this$1.base + route.fullPath));
- handleScroll(this$1.router, route, fromRoute, false);
- onComplete && onComplete(route);
- }, onAbort);
- };
+ }
+ };
- HTML5History.prototype.replace = function replace (location, onComplete, onAbort) {
- var this$1 = this;
+ var on = { click: guardEvent };
+ if (Array.isArray(this.event)) {
+ this.event.forEach(function (e) { on[e] = handler; });
+ } else {
+ on[this.event] = handler;
+ }
- var ref = this;
- var fromRoute = ref.current;
- this.transitionTo(location, function (route) {
- replaceState(cleanPath(this$1.base + route.fullPath));
- handleScroll(this$1.router, route, fromRoute, false);
- onComplete && onComplete(route);
- }, onAbort);
- };
+ var data = {
+ class: classes
+ };
- HTML5History.prototype.ensureURL = function ensureURL (push) {
- if (getLocation(this.base) !== this.current.fullPath) {
- var current = cleanPath(this.base + this.current.fullPath);
- push ? pushState(current) : replaceState(current);
+ if (this.tag === 'a') {
+ data.on = on;
+ data.attrs = { href: href };
+ } else {
+ // find the first child and apply listener and href
+ var a = findAnchor(this.$slots.default);
+ if (a) {
+ // in case the is a static node
+ a.isStatic = false;
+ var extend = _Vue.util.extend;
+ var aData = a.data = extend({}, a.data);
+ aData.on = on;
+ var aAttrs = a.data.attrs = extend({}, a.data.attrs);
+ aAttrs.href = href;
+ } else {
+ // doesn't have child, apply listener to self
+ data.on = on;
+ }
}
- };
- HTML5History.prototype.getCurrentLocation = function getCurrentLocation () {
- return getLocation(this.base)
- };
-
- return HTML5History;
-}(History));
+ return h(this.tag, data, this.$slots.default)
+ }
+};
-function getLocation (base) {
- var path = window.location.pathname;
- if (base && path.indexOf(base) === 0) {
- path = path.slice(base.length);
+function guardEvent (e) {
+ // don't redirect with control keys
+ if (e.metaKey || e.altKey || e.ctrlKey || e.shiftKey) { return }
+ // don't redirect when preventDefault called
+ if (e.defaultPrevented) { return }
+ // don't redirect on right click
+ if (e.button !== undefined && e.button !== 0) { return }
+ // don't redirect if `target="_blank"`
+ if (e.currentTarget && e.currentTarget.getAttribute) {
+ var target = e.currentTarget.getAttribute('target');
+ if (/\b_blank\b/i.test(target)) { return }
}
- return (path || '/') + window.location.search + window.location.hash
+ // this may be a Weex event which doesn't have this method
+ if (e.preventDefault) {
+ e.preventDefault();
+ }
+ return true
}
-/* */
-
-
-var HashHistory = (function (History$$1) {
- function HashHistory (router, base, fallback) {
- History$$1.call(this, router, base);
- // check history fallback deeplinking
- if (fallback && checkFallback(this.base)) {
- return
+function findAnchor (children) {
+ if (children) {
+ var child;
+ for (var i = 0; i < children.length; i++) {
+ child = children[i];
+ if (child.tag === 'a') {
+ return child
+ }
+ if (child.children && (child = findAnchor(child.children))) {
+ return child
+ }
}
- ensureSlash();
}
+}
- if ( History$$1 ) HashHistory.__proto__ = History$$1;
- HashHistory.prototype = Object.create( History$$1 && History$$1.prototype );
- HashHistory.prototype.constructor = HashHistory;
-
- // this is delayed until the app mounts
- // to avoid the hashchange listener being fired too early
- HashHistory.prototype.setupListeners = function setupListeners () {
- var this$1 = this;
-
- window.addEventListener('hashchange', function () {
- if (!ensureSlash()) {
- return
- }
- this$1.transitionTo(getHash(), function (route) {
- replaceHash(route.fullPath);
- });
- });
- };
+var _Vue;
- HashHistory.prototype.push = function push (location, onComplete, onAbort) {
- this.transitionTo(location, function (route) {
- pushHash(route.fullPath);
- onComplete && onComplete(route);
- }, onAbort);
- };
+function install (Vue) {
+ if (install.installed) { return }
+ install.installed = true;
- HashHistory.prototype.replace = function replace (location, onComplete, onAbort) {
- this.transitionTo(location, function (route) {
- replaceHash(route.fullPath);
- onComplete && onComplete(route);
- }, onAbort);
- };
+ _Vue = Vue;
- HashHistory.prototype.go = function go (n) {
- window.history.go(n);
- };
+ var isDef = function (v) { return v !== undefined; };
- HashHistory.prototype.ensureURL = function ensureURL (push) {
- var current = this.current.fullPath;
- if (getHash() !== current) {
- push ? pushHash(current) : replaceHash(current);
+ var registerInstance = function (vm, callVal) {
+ var i = vm.$options._parentVnode;
+ if (isDef(i) && isDef(i = i.data) && isDef(i = i.registerRouteInstance)) {
+ i(vm, callVal);
}
};
- HashHistory.prototype.getCurrentLocation = function getCurrentLocation () {
- return getHash()
- };
+ Vue.mixin({
+ beforeCreate: function beforeCreate () {
+ if (isDef(this.$options.router)) {
+ this._routerRoot = this;
+ this._router = this.$options.router;
+ this._router.init(this);
+ Vue.util.defineReactive(this, '_route', this._router.history.current);
+ } else {
+ this._routerRoot = (this.$parent && this.$parent._routerRoot) || this;
+ }
+ registerInstance(this, this);
+ },
+ destroyed: function destroyed () {
+ registerInstance(this);
+ }
+ });
- return HashHistory;
-}(History));
+ Object.defineProperty(Vue.prototype, '$router', {
+ get: function get () { return this._routerRoot._router }
+ });
-function checkFallback (base) {
- var location = getLocation(base);
- if (!/^\/#/.test(location)) {
- window.location.replace(
- cleanPath(base + '/#' + location)
- );
- return true
- }
-}
+ Object.defineProperty(Vue.prototype, '$route', {
+ get: function get () { return this._routerRoot._route }
+ });
-function ensureSlash () {
- var path = getHash();
- if (path.charAt(0) === '/') {
- return true
- }
- replaceHash('/' + path);
- return false
-}
+ Vue.component('router-view', View);
+ Vue.component('router-link', Link);
-function getHash () {
- // We can't use window.location.hash here because it's not
- // consistent across browsers - Firefox will pre-decode it!
- var href = window.location.href;
- var index = href.indexOf('#');
- return index === -1 ? '' : href.slice(index + 1)
+ var strats = Vue.config.optionMergeStrategies;
+ // use the same hook merging strategy for route hooks
+ strats.beforeRouteEnter = strats.beforeRouteLeave = strats.beforeRouteUpdate = strats.created;
}
-function pushHash (path) {
- window.location.hash = path;
-}
+/* */
-function replaceHash (path) {
- var href = window.location.href;
- var i = href.indexOf('#');
- var base = i >= 0 ? href.slice(0, i) : href;
- window.location.replace((base + "#" + path));
-}
+var inBrowser = typeof window !== 'undefined';
/* */
-
-var AbstractHistory = (function (History$$1) {
- function AbstractHistory (router, base) {
- History$$1.call(this, router, base);
- this.stack = [];
- this.index = -1;
+function resolvePath (
+ relative,
+ base,
+ append
+) {
+ var firstChar = relative.charAt(0);
+ if (firstChar === '/') {
+ return relative
}
- if ( History$$1 ) AbstractHistory.__proto__ = History$$1;
- AbstractHistory.prototype = Object.create( History$$1 && History$$1.prototype );
- AbstractHistory.prototype.constructor = AbstractHistory;
-
- AbstractHistory.prototype.push = function push (location, onComplete, onAbort) {
- var this$1 = this;
-
- this.transitionTo(location, function (route) {
- this$1.stack = this$1.stack.slice(0, this$1.index + 1).concat(route);
- this$1.index++;
- onComplete && onComplete(route);
- }, onAbort);
- };
-
- AbstractHistory.prototype.replace = function replace (location, onComplete, onAbort) {
- var this$1 = this;
+ if (firstChar === '?' || firstChar === '#') {
+ return base + relative
+ }
- this.transitionTo(location, function (route) {
- this$1.stack = this$1.stack.slice(0, this$1.index).concat(route);
- onComplete && onComplete(route);
- }, onAbort);
- };
+ var stack = base.split('/');
- AbstractHistory.prototype.go = function go (n) {
- var this$1 = this;
+ // remove trailing segment if:
+ // - not appending
+ // - appending to trailing slash (last segment is empty)
+ if (!append || !stack[stack.length - 1]) {
+ stack.pop();
+ }
- var targetIndex = this.index + n;
- if (targetIndex < 0 || targetIndex >= this.stack.length) {
- return
+ // resolve relative path
+ var segments = relative.replace(/^\//, '').split('/');
+ for (var i = 0; i < segments.length; i++) {
+ var segment = segments[i];
+ if (segment === '..') {
+ stack.pop();
+ } else if (segment !== '.') {
+ stack.push(segment);
}
- var route = this.stack[targetIndex];
- this.confirmTransition(route, function () {
- this$1.index = targetIndex;
- this$1.updateRoute(route);
- });
- };
-
- AbstractHistory.prototype.getCurrentLocation = function getCurrentLocation () {
- var current = this.stack[this.stack.length - 1];
- return current ? current.fullPath : '/'
- };
-
- AbstractHistory.prototype.ensureURL = function ensureURL () {
- // noop
- };
-
- return AbstractHistory;
-}(History));
+ }
-/* */
+ // ensure leading slash
+ if (stack[0] !== '') {
+ stack.unshift('');
+ }
-var VueRouter = function VueRouter (options) {
- if ( options === void 0 ) options = {};
+ return stack.join('/')
+}
- this.app = null;
- this.apps = [];
- this.options = options;
- this.beforeHooks = [];
- this.resolveHooks = [];
- this.afterHooks = [];
- this.matcher = createMatcher(options.routes || [], this);
+function parsePath (path) {
+ var hash = '';
+ var query = '';
- var mode = options.mode || 'hash';
- this.fallback = mode === 'history' && !supportsPushState && options.fallback !== false;
- if (this.fallback) {
- mode = 'hash';
+ var hashIndex = path.indexOf('#');
+ if (hashIndex >= 0) {
+ hash = path.slice(hashIndex);
+ path = path.slice(0, hashIndex);
}
- if (!inBrowser) {
- mode = 'abstract';
+
+ var queryIndex = path.indexOf('?');
+ if (queryIndex >= 0) {
+ query = path.slice(queryIndex + 1);
+ path = path.slice(0, queryIndex);
}
- this.mode = mode;
- switch (mode) {
- case 'history':
- this.history = new HTML5History(this, options.base);
- break
- case 'hash':
- this.history = new HashHistory(this, options.base, this.fallback);
- break
- case 'abstract':
- this.history = new AbstractHistory(this, options.base);
- break
- default:
- if (true) {
- assert(false, ("invalid mode: " + mode));
- }
+ return {
+ path: path,
+ query: query,
+ hash: hash
}
-};
+}
-var prototypeAccessors = { currentRoute: {} };
+function cleanPath (path) {
+ return path.replace(/\/\//g, '/')
+}
-VueRouter.prototype.match = function match (
- raw,
- current,
- redirectedFrom
-) {
- return this.matcher.match(raw, current, redirectedFrom)
+var index$1 = Array.isArray || function (arr) {
+ return Object.prototype.toString.call(arr) == '[object Array]';
};
-prototypeAccessors.currentRoute.get = function () {
- return this.history && this.history.current
-};
+/**
+ * Expose `pathToRegexp`.
+ */
+var index = pathToRegexp;
+var parse_1 = parse;
+var compile_1 = compile;
+var tokensToFunction_1 = tokensToFunction;
+var tokensToRegExp_1 = tokensToRegExp;
-VueRouter.prototype.init = function init (app /* Vue component instance */) {
- var this$1 = this;
+/**
+ * The main path matching regexp utility.
+ *
+ * @type {RegExp}
+ */
+var PATH_REGEXP = new RegExp([
+ // Match escaped characters that would otherwise appear in future matches.
+ // This allows the user to escape special characters that won't transform.
+ '(\\\\.)',
+ // Match Express-style parameters and un-named parameters with a prefix
+ // and optional suffixes. Matches appear as:
+ //
+ // "/:test(\\d+)?" => ["/", "test", "\d+", undefined, "?", undefined]
+ // "/route(\\d+)" => [undefined, undefined, undefined, "\d+", undefined, undefined]
+ // "/*" => ["/", undefined, undefined, undefined, undefined, "*"]
+ '([\\/.])?(?:(?:\\:(\\w+)(?:\\(((?:\\\\.|[^\\\\()])+)\\))?|\\(((?:\\\\.|[^\\\\()])+)\\))([+*?])?|(\\*))'
+].join('|'), 'g');
- "development" !== 'production' && assert(
- install.installed,
- "not installed. Make sure to call `Vue.use(VueRouter)` " +
- "before creating root instance."
- );
+/**
+ * Parse a string for the raw tokens.
+ *
+ * @param {string} str
+ * @param {Object=} options
+ * @return {!Array}
+ */
+function parse (str, options) {
+ var tokens = [];
+ var key = 0;
+ var index = 0;
+ var path = '';
+ var defaultDelimiter = options && options.delimiter || '/';
+ var res;
- this.apps.push(app);
+ while ((res = PATH_REGEXP.exec(str)) != null) {
+ var m = res[0];
+ var escaped = res[1];
+ var offset = res.index;
+ path += str.slice(index, offset);
+ index = offset + m.length;
- // main app already initialized.
- if (this.app) {
- return
- }
+ // Ignore already escaped sequences.
+ if (escaped) {
+ path += escaped[1];
+ continue
+ }
- this.app = app;
+ var next = str[index];
+ var prefix = res[2];
+ var name = res[3];
+ var capture = res[4];
+ var group = res[5];
+ var modifier = res[6];
+ var asterisk = res[7];
- var history = this.history;
+ // Push the current path onto the tokens.
+ if (path) {
+ tokens.push(path);
+ path = '';
+ }
- if (history instanceof HTML5History) {
- history.transitionTo(history.getCurrentLocation());
- } else if (history instanceof HashHistory) {
- var setupHashListener = function () {
- history.setupListeners();
- };
- history.transitionTo(
- history.getCurrentLocation(),
- setupHashListener,
- setupHashListener
- );
- }
+ var partial = prefix != null && next != null && next !== prefix;
+ var repeat = modifier === '+' || modifier === '*';
+ var optional = modifier === '?' || modifier === '*';
+ var delimiter = res[2] || defaultDelimiter;
+ var pattern = capture || group;
- history.listen(function (route) {
- this$1.apps.forEach(function (app) {
- app._route = route;
+ tokens.push({
+ name: name || key++,
+ prefix: prefix || '',
+ delimiter: delimiter,
+ optional: optional,
+ repeat: repeat,
+ partial: partial,
+ asterisk: !!asterisk,
+ pattern: pattern ? escapeGroup(pattern) : (asterisk ? '.*' : '[^' + escapeString(delimiter) + ']+?')
});
- });
-};
-
-VueRouter.prototype.beforeEach = function beforeEach (fn) {
- return registerHook(this.beforeHooks, fn)
-};
-
-VueRouter.prototype.beforeResolve = function beforeResolve (fn) {
- return registerHook(this.resolveHooks, fn)
-};
-
-VueRouter.prototype.afterEach = function afterEach (fn) {
- return registerHook(this.afterHooks, fn)
-};
-
-VueRouter.prototype.onReady = function onReady (cb, errorCb) {
- this.history.onReady(cb, errorCb);
-};
-
-VueRouter.prototype.onError = function onError (errorCb) {
- this.history.onError(errorCb);
-};
-
-VueRouter.prototype.push = function push (location, onComplete, onAbort) {
- this.history.push(location, onComplete, onAbort);
-};
-
-VueRouter.prototype.replace = function replace (location, onComplete, onAbort) {
- this.history.replace(location, onComplete, onAbort);
-};
-
-VueRouter.prototype.go = function go (n) {
- this.history.go(n);
-};
-
-VueRouter.prototype.back = function back () {
- this.go(-1);
-};
-
-VueRouter.prototype.forward = function forward () {
- this.go(1);
-};
-
-VueRouter.prototype.getMatchedComponents = function getMatchedComponents (to) {
- var route = to
- ? to.matched
- ? to
- : this.resolve(to).route
- : this.currentRoute;
- if (!route) {
- return []
}
- return [].concat.apply([], route.matched.map(function (m) {
- return Object.keys(m.components).map(function (key) {
- return m.components[key]
- })
- }))
-};
-VueRouter.prototype.resolve = function resolve (
- to,
- current,
- append
-) {
- var location = normalizeLocation(
- to,
- current || this.history.current,
- append,
- this
- );
- var route = this.match(location, current);
- var fullPath = route.redirectedFrom || route.fullPath;
- var base = this.history.base;
- var href = createHref(base, fullPath, this.mode);
- return {
- location: location,
- route: route,
- href: href,
- // for backwards compat
- normalizedTo: location,
- resolved: route
+ // Match any characters still remaining.
+ if (index < str.length) {
+ path += str.substr(index);
}
-};
-VueRouter.prototype.addRoutes = function addRoutes (routes) {
- this.matcher.addRoutes(routes);
- if (this.history.current !== START) {
- this.history.transitionTo(this.history.getCurrentLocation());
+ // If the path exists, push it onto the end.
+ if (path) {
+ tokens.push(path);
}
-};
-Object.defineProperties( VueRouter.prototype, prototypeAccessors );
-
-function registerHook (list, fn) {
- list.push(fn);
- return function () {
- var i = list.indexOf(fn);
- if (i > -1) { list.splice(i, 1); }
- }
+ return tokens
}
-function createHref (base, fullPath, mode) {
- var path = mode === 'hash' ? '#' + fullPath : fullPath;
- return base ? cleanPath(base + '/' + path) : path
+/**
+ * Compile a string to a template function for the path.
+ *
+ * @param {string} str
+ * @param {Object=} options
+ * @return {!function(Object=, Object=)}
+ */
+function compile (str, options) {
+ return tokensToFunction(parse(str, options))
}
-VueRouter.install = install;
-VueRouter.version = '2.7.0';
-
-if (inBrowser && window.Vue) {
- window.Vue.use(VueRouter);
+/**
+ * Prettier encoding of URI path segments.
+ *
+ * @param {string}
+ * @return {string}
+ */
+function encodeURIComponentPretty (str) {
+ return encodeURI(str).replace(/[\/?#]/g, function (c) {
+ return '%' + c.charCodeAt(0).toString(16).toUpperCase()
+ })
}
-/* harmony default export */ __webpack_exports__["default"] = (VueRouter);
-
+/**
+ * Encode the asterisk parameter. Similar to `pretty`, but allows slashes.
+ *
+ * @param {string}
+ * @return {string}
+ */
+function encodeAsterisk (str) {
+ return encodeURI(str).replace(/[?#]/g, function (c) {
+ return '%' + c.charCodeAt(0).toString(16).toUpperCase()
+ })
+}
-/***/ }),
-/* 40 */
-/***/ (function(module, exports, __webpack_require__) {
+/**
+ * Expose a method for transforming tokens into the path function.
+ */
+function tokensToFunction (tokens) {
+ // Compile all the tokens into regexps.
+ var matches = new Array(tokens.length);
-module.exports =
-/******/ (function(modules) { // webpackBootstrap
-/******/ // The module cache
-/******/ var installedModules = {};
+ // Compile all the patterns before compilation.
+ for (var i = 0; i < tokens.length; i++) {
+ if (typeof tokens[i] === 'object') {
+ matches[i] = new RegExp('^(?:' + tokens[i].pattern + ')$');
+ }
+ }
-/******/ // The require function
-/******/ function __webpack_require__(moduleId) {
+ return function (obj, opts) {
+ var path = '';
+ var data = obj || {};
+ var options = opts || {};
+ var encode = options.pretty ? encodeURIComponentPretty : encodeURIComponent;
-/******/ // Check if module is in cache
-/******/ if(installedModules[moduleId])
-/******/ return installedModules[moduleId].exports;
+ for (var i = 0; i < tokens.length; i++) {
+ var token = tokens[i];
-/******/ // Create a new module (and put it into the cache)
-/******/ var module = installedModules[moduleId] = {
-/******/ exports: {},
-/******/ id: moduleId,
-/******/ loaded: false
-/******/ };
+ if (typeof token === 'string') {
+ path += token;
-/******/ // Execute the module function
-/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
+ continue
+ }
-/******/ // Flag the module as loaded
-/******/ module.loaded = true;
+ var value = data[token.name];
+ var segment;
-/******/ // Return the exports of the module
-/******/ return module.exports;
-/******/ }
+ if (value == null) {
+ if (token.optional) {
+ // Prepend partial segment prefixes.
+ if (token.partial) {
+ path += token.prefix;
+ }
+ continue
+ } else {
+ throw new TypeError('Expected "' + token.name + '" to be defined')
+ }
+ }
-/******/ // expose the modules object (__webpack_modules__)
-/******/ __webpack_require__.m = modules;
+ if (index$1(value)) {
+ if (!token.repeat) {
+ throw new TypeError('Expected "' + token.name + '" to not repeat, but received `' + JSON.stringify(value) + '`')
+ }
-/******/ // expose the module cache
-/******/ __webpack_require__.c = installedModules;
+ if (value.length === 0) {
+ if (token.optional) {
+ continue
+ } else {
+ throw new TypeError('Expected "' + token.name + '" to not be empty')
+ }
+ }
-/******/ // __webpack_public_path__
-/******/ __webpack_require__.p = "/dist/";
+ for (var j = 0; j < value.length; j++) {
+ segment = encode(value[j]);
-/******/ // Load entry module and return exports
-/******/ return __webpack_require__(0);
-/******/ })
-/************************************************************************/
-/******/ ([
-/* 0 */
-/***/ function(module, exports, __webpack_require__) {
+ if (!matches[i].test(segment)) {
+ throw new TypeError('Expected all "' + token.name + '" to match "' + token.pattern + '", but received `' + JSON.stringify(segment) + '`')
+ }
- module.exports = __webpack_require__(1);
+ path += (j === 0 ? token.prefix : token.delimiter) + segment;
+ }
+ continue
+ }
-/***/ },
-/* 1 */
-/***/ function(module, exports, __webpack_require__) {
+ segment = token.asterisk ? encodeAsterisk(value) : encode(value);
- 'use strict';
+ if (!matches[i].test(segment)) {
+ throw new TypeError('Expected "' + token.name + '" to match "' + token.pattern + '", but received "' + segment + '"')
+ }
- var _index = __webpack_require__(2);
+ path += token.prefix + segment;
+ }
- var _index2 = _interopRequireDefault(_index);
+ return path
+ }
+}
- var _index3 = __webpack_require__(11);
+/**
+ * Escape a regular expression string.
+ *
+ * @param {string} str
+ * @return {string}
+ */
+function escapeString (str) {
+ return str.replace(/([.+*?=^!:${}()[\]|\/\\])/g, '\\$1')
+}
- var _index4 = _interopRequireDefault(_index3);
+/**
+ * Escape the capturing group by escaping special characters and meaning.
+ *
+ * @param {string} group
+ * @return {string}
+ */
+function escapeGroup (group) {
+ return group.replace(/([=!:$\/()])/g, '\\$1')
+}
- var _index5 = __webpack_require__(17);
+/**
+ * Attach the keys as a property of the regexp.
+ *
+ * @param {!RegExp} re
+ * @param {Array} keys
+ * @return {!RegExp}
+ */
+function attachKeys (re, keys) {
+ re.keys = keys;
+ return re
+}
- var _index6 = _interopRequireDefault(_index5);
+/**
+ * Get the flags for a regexp from the options.
+ *
+ * @param {Object} options
+ * @return {string}
+ */
+function flags (options) {
+ return options.sensitive ? '' : 'i'
+}
- var _index7 = __webpack_require__(28);
+/**
+ * Pull out keys from a regexp.
+ *
+ * @param {!RegExp} path
+ * @param {!Array} keys
+ * @return {!RegExp}
+ */
+function regexpToRegexp (path, keys) {
+ // Use a negative lookahead to match only capturing groups.
+ var groups = path.source.match(/\((?!\?)/g);
- var _index8 = _interopRequireDefault(_index7);
+ if (groups) {
+ for (var i = 0; i < groups.length; i++) {
+ keys.push({
+ name: i,
+ prefix: null,
+ delimiter: null,
+ optional: false,
+ repeat: false,
+ partial: false,
+ asterisk: false,
+ pattern: null
+ });
+ }
+ }
- var _index9 = __webpack_require__(33);
+ return attachKeys(path, keys)
+}
- var _index10 = _interopRequireDefault(_index9);
+/**
+ * Transform an array into a regexp.
+ *
+ * @param {!Array} path
+ * @param {Array} keys
+ * @param {!Object} options
+ * @return {!RegExp}
+ */
+function arrayToRegexp (path, keys, options) {
+ var parts = [];
- var _index11 = __webpack_require__(37);
+ for (var i = 0; i < path.length; i++) {
+ parts.push(pathToRegexp(path[i], keys, options).source);
+ }
- var _index12 = _interopRequireDefault(_index11);
+ var regexp = new RegExp('(?:' + parts.join('|') + ')', flags(options));
- var _index13 = __webpack_require__(41);
+ return attachKeys(regexp, keys)
+}
- var _index14 = _interopRequireDefault(_index13);
+/**
+ * Create a path regexp from string input.
+ *
+ * @param {string} path
+ * @param {!Array} keys
+ * @param {!Object} options
+ * @return {!RegExp}
+ */
+function stringToRegexp (path, keys, options) {
+ return tokensToRegExp(parse(path, options), keys, options)
+}
- var _index15 = __webpack_require__(46);
+/**
+ * Expose a function for taking tokens and returning a RegExp.
+ *
+ * @param {!Array} tokens
+ * @param {(Array|Object)=} keys
+ * @param {Object=} options
+ * @return {!RegExp}
+ */
+function tokensToRegExp (tokens, keys, options) {
+ if (!index$1(keys)) {
+ options = /** @type {!Object} */ (keys || options);
+ keys = [];
+ }
- var _index16 = _interopRequireDefault(_index15);
+ options = options || {};
- var _index17 = __webpack_require__(52);
+ var strict = options.strict;
+ var end = options.end !== false;
+ var route = '';
- var _index18 = _interopRequireDefault(_index17);
+ // Iterate over the tokens and create our regexp string.
+ for (var i = 0; i < tokens.length; i++) {
+ var token = tokens[i];
- var _index19 = __webpack_require__(56);
+ if (typeof token === 'string') {
+ route += escapeString(token);
+ } else {
+ var prefix = escapeString(token.prefix);
+ var capture = '(?:' + token.pattern + ')';
- var _index20 = _interopRequireDefault(_index19);
+ keys.push(token);
- var _index21 = __webpack_require__(60);
+ if (token.repeat) {
+ capture += '(?:' + prefix + capture + ')*';
+ }
- var _index22 = _interopRequireDefault(_index21);
+ if (token.optional) {
+ if (!token.partial) {
+ capture = '(?:' + prefix + '(' + capture + '))?';
+ } else {
+ capture = prefix + '(' + capture + ')?';
+ }
+ } else {
+ capture = prefix + '(' + capture + ')';
+ }
- var _index23 = __webpack_require__(66);
+ route += capture;
+ }
+ }
- var _index24 = _interopRequireDefault(_index23);
+ var delimiter = escapeString(options.delimiter || '/');
+ var endsWithDelimiter = route.slice(-delimiter.length) === delimiter;
- var _index25 = __webpack_require__(71);
-
- var _index26 = _interopRequireDefault(_index25);
+ // In non-strict mode we allow a slash at the end of match. If the path to
+ // match already ends with a slash, we remove it for consistency. The slash
+ // is valid at the end of a path match, not in the middle. This is important
+ // in non-ending mode, where "/test/" shouldn't match "/test//route".
+ if (!strict) {
+ route = (endsWithDelimiter ? route.slice(0, -delimiter.length) : route) + '(?:' + delimiter + '(?=$))?';
+ }
- var _index27 = __webpack_require__(75);
+ if (end) {
+ route += '$';
+ } else {
+ // In non-ending mode, we need the capturing groups to match as much as
+ // possible by using a positive lookahead to the end or next path segment.
+ route += strict && endsWithDelimiter ? '' : '(?=' + delimiter + '|$)';
+ }
- var _index28 = _interopRequireDefault(_index27);
+ return attachKeys(new RegExp('^' + route, flags(options)), keys)
+}
- var _index29 = __webpack_require__(79);
+/**
+ * Normalize the given path string, returning a regular expression.
+ *
+ * An empty array can be passed in for the keys, which will hold the
+ * placeholder key descriptions. For example, using `/user/:id`, `keys` will
+ * contain `[{ name: 'id', delimiter: '/', optional: false, repeat: false }]`.
+ *
+ * @param {(string|RegExp|Array)} path
+ * @param {(Array|Object)=} keys
+ * @param {Object=} options
+ * @return {!RegExp}
+ */
+function pathToRegexp (path, keys, options) {
+ if (!index$1(keys)) {
+ options = /** @type {!Object} */ (keys || options);
+ keys = [];
+ }
- var _index30 = _interopRequireDefault(_index29);
+ options = options || {};
- var _index31 = __webpack_require__(83);
+ if (path instanceof RegExp) {
+ return regexpToRegexp(path, /** @type {!Array} */ (keys))
+ }
- var _index32 = _interopRequireDefault(_index31);
+ if (index$1(path)) {
+ return arrayToRegexp(/** @type {!Array} */ (path), /** @type {!Array} */ (keys), options)
+ }
- var _index33 = __webpack_require__(87);
+ return stringToRegexp(/** @type {string} */ (path), /** @type {!Array} */ (keys), options)
+}
- var _index34 = _interopRequireDefault(_index33);
+index.parse = parse_1;
+index.compile = compile_1;
+index.tokensToFunction = tokensToFunction_1;
+index.tokensToRegExp = tokensToRegExp_1;
- var _index35 = __webpack_require__(91);
+/* */
- var _index36 = _interopRequireDefault(_index35);
+var regexpCompileCache = Object.create(null);
- var _index37 = __webpack_require__(95);
+function fillParams (
+ path,
+ params,
+ routeMsg
+) {
+ try {
+ var filler =
+ regexpCompileCache[path] ||
+ (regexpCompileCache[path] = index.compile(path));
+ return filler(params || {}, { pretty: true })
+ } catch (e) {
+ if (true) {
+ warn(false, ("missing param for " + routeMsg + ": " + (e.message)));
+ }
+ return ''
+ }
+}
- var _index38 = _interopRequireDefault(_index37);
+/* */
- var _index39 = __webpack_require__(99);
+function createRouteMap (
+ routes,
+ oldPathList,
+ oldPathMap,
+ oldNameMap
+) {
+ // the path list is used to control path matching priority
+ var pathList = oldPathList || [];
+ var pathMap = oldPathMap || Object.create(null);
+ var nameMap = oldNameMap || Object.create(null);
- var _index40 = _interopRequireDefault(_index39);
+ routes.forEach(function (route) {
+ addRouteRecord(pathList, pathMap, nameMap, route);
+ });
- var _index41 = __webpack_require__(114);
+ // ensure wildcard routes are always at the end
+ for (var i = 0, l = pathList.length; i < l; i++) {
+ if (pathList[i] === '*') {
+ pathList.push(pathList.splice(i, 1)[0]);
+ l--;
+ i--;
+ }
+ }
- var _index42 = _interopRequireDefault(_index41);
+ return {
+ pathList: pathList,
+ pathMap: pathMap,
+ nameMap: nameMap
+ }
+}
- var _index43 = __webpack_require__(115);
+function addRouteRecord (
+ pathList,
+ pathMap,
+ nameMap,
+ route,
+ parent,
+ matchAs
+) {
+ var path = route.path;
+ var name = route.name;
+ if (true) {
+ assert(path != null, "\"path\" is required in a route configuration.");
+ assert(
+ typeof route.component !== 'string',
+ "route config \"component\" for path: " + (String(path || name)) + " cannot be a " +
+ "string id. Use an actual component instead."
+ );
+ }
- var _index44 = _interopRequireDefault(_index43);
+ var normalizedPath = normalizePath(path, parent);
+ var pathToRegexpOptions = route.pathToRegexpOptions || {};
- var _index45 = __webpack_require__(119);
+ if (typeof route.caseSensitive === 'boolean') {
+ pathToRegexpOptions.sensitive = route.caseSensitive;
+ }
- var _index46 = _interopRequireDefault(_index45);
+ var record = {
+ path: normalizedPath,
+ regex: compileRouteRegex(normalizedPath, pathToRegexpOptions),
+ components: route.components || { default: route.component },
+ instances: {},
+ name: name,
+ parent: parent,
+ matchAs: matchAs,
+ redirect: route.redirect,
+ beforeEnter: route.beforeEnter,
+ meta: route.meta || {},
+ props: route.props == null
+ ? {}
+ : route.components
+ ? route.props
+ : { default: route.props }
+ };
- var _index47 = __webpack_require__(123);
+ if (route.children) {
+ // Warn if route is named, does not redirect and has a default child route.
+ // If users navigate to this route by name, the default child will
+ // not be rendered (GH Issue #629)
+ if (true) {
+ if (route.name && !route.redirect && route.children.some(function (child) { return /^\/?$/.test(child.path); })) {
+ warn(
+ false,
+ "Named Route '" + (route.name) + "' has a default child route. " +
+ "When navigating to this named route (:to=\"{name: '" + (route.name) + "'\"), " +
+ "the default child route will not be rendered. Remove the name from " +
+ "this route and use the name of the default child route for named " +
+ "links instead."
+ );
+ }
+ }
+ route.children.forEach(function (child) {
+ var childMatchAs = matchAs
+ ? cleanPath((matchAs + "/" + (child.path)))
+ : undefined;
+ addRouteRecord(pathList, pathMap, nameMap, child, record, childMatchAs);
+ });
+ }
- var _index48 = _interopRequireDefault(_index47);
+ if (route.alias !== undefined) {
+ var aliases = Array.isArray(route.alias)
+ ? route.alias
+ : [route.alias];
- var _index49 = __webpack_require__(127);
+ aliases.forEach(function (alias) {
+ var aliasRoute = {
+ path: alias,
+ children: route.children
+ };
+ addRouteRecord(
+ pathList,
+ pathMap,
+ nameMap,
+ aliasRoute,
+ parent,
+ record.path || '/' // matchAs
+ );
+ });
+ }
- var _index50 = _interopRequireDefault(_index49);
+ if (!pathMap[record.path]) {
+ pathList.push(record.path);
+ pathMap[record.path] = record;
+ }
- var _index51 = __webpack_require__(147);
+ if (name) {
+ if (!nameMap[name]) {
+ nameMap[name] = record;
+ } else if ("development" !== 'production' && !matchAs) {
+ warn(
+ false,
+ "Duplicate named routes definition: " +
+ "{ name: \"" + name + "\", path: \"" + (record.path) + "\" }"
+ );
+ }
+ }
+}
- var _index52 = _interopRequireDefault(_index51);
+function compileRouteRegex (path, pathToRegexpOptions) {
+ var regex = index(path, [], pathToRegexpOptions);
+ if (true) {
+ var keys = {};
+ regex.keys.forEach(function (key) {
+ warn(!keys[key.name], ("Duplicate param keys in route with path: \"" + path + "\""));
+ keys[key.name] = true;
+ });
+ }
+ return regex
+}
- var _index53 = __webpack_require__(149);
+function normalizePath (path, parent) {
+ path = path.replace(/\/$/, '');
+ if (path[0] === '/') { return path }
+ if (parent == null) { return path }
+ return cleanPath(((parent.path) + "/" + path))
+}
- var _index54 = _interopRequireDefault(_index53);
+/* */
- var _index55 = __webpack_require__(177);
- var _index56 = _interopRequireDefault(_index55);
+function normalizeLocation (
+ raw,
+ current,
+ append,
+ router
+) {
+ var next = typeof raw === 'string' ? { path: raw } : raw;
+ // named target
+ if (next.name || next._normalized) {
+ return next
+ }
- var _index57 = __webpack_require__(182);
+ // relative params
+ if (!next.path && next.params && current) {
+ next = assign({}, next);
+ next._normalized = true;
+ var params = assign(assign({}, current.params), next.params);
+ if (current.name) {
+ next.name = current.name;
+ next.params = params;
+ } else if (current.matched.length) {
+ var rawPath = current.matched[current.matched.length - 1].path;
+ next.path = fillParams(rawPath, params, ("path " + (current.path)));
+ } else if (true) {
+ warn(false, "relative params navigation requires a current route.");
+ }
+ return next
+ }
- var _index58 = _interopRequireDefault(_index57);
+ var parsedPath = parsePath(next.path || '');
+ var basePath = (current && current.path) || '/';
+ var path = parsedPath.path
+ ? resolvePath(parsedPath.path, basePath, append || next.append)
+ : basePath;
- var _index59 = __webpack_require__(187);
+ var query = resolveQuery(
+ parsedPath.query,
+ next.query,
+ router && router.options.parseQuery
+ );
- var _index60 = _interopRequireDefault(_index59);
+ var hash = next.hash || parsedPath.hash;
+ if (hash && hash.charAt(0) !== '#') {
+ hash = "#" + hash;
+ }
- var _index61 = __webpack_require__(192);
+ return {
+ _normalized: true,
+ path: path,
+ query: query,
+ hash: hash
+ }
+}
- var _index62 = _interopRequireDefault(_index61);
+function assign (a, b) {
+ for (var key in b) {
+ a[key] = b[key];
+ }
+ return a
+}
- var _index63 = __webpack_require__(195);
+/* */
- var _index64 = _interopRequireDefault(_index63);
- var _index65 = __webpack_require__(200);
+function createMatcher (
+ routes,
+ router
+) {
+ var ref = createRouteMap(routes);
+ var pathList = ref.pathList;
+ var pathMap = ref.pathMap;
+ var nameMap = ref.nameMap;
- var _index66 = _interopRequireDefault(_index65);
+ function addRoutes (routes) {
+ createRouteMap(routes, pathList, pathMap, nameMap);
+ }
- var _index67 = __webpack_require__(204);
+ function match (
+ raw,
+ currentRoute,
+ redirectedFrom
+ ) {
+ var location = normalizeLocation(raw, currentRoute, false, router);
+ var name = location.name;
- var _index68 = _interopRequireDefault(_index67);
+ if (name) {
+ var record = nameMap[name];
+ if (true) {
+ warn(record, ("Route with name '" + name + "' does not exist"));
+ }
+ if (!record) { return _createRoute(null, location) }
+ var paramNames = record.regex.keys
+ .filter(function (key) { return !key.optional; })
+ .map(function (key) { return key.name; });
- var _index69 = __webpack_require__(208);
+ if (typeof location.params !== 'object') {
+ location.params = {};
+ }
- var _index70 = _interopRequireDefault(_index69);
+ if (currentRoute && typeof currentRoute.params === 'object') {
+ for (var key in currentRoute.params) {
+ if (!(key in location.params) && paramNames.indexOf(key) > -1) {
+ location.params[key] = currentRoute.params[key];
+ }
+ }
+ }
- var _index71 = __webpack_require__(212);
+ if (record) {
+ location.path = fillParams(record.path, location.params, ("named route \"" + name + "\""));
+ return _createRoute(record, location, redirectedFrom)
+ }
+ } else if (location.path) {
+ location.params = {};
+ for (var i = 0; i < pathList.length; i++) {
+ var path = pathList[i];
+ var record$1 = pathMap[path];
+ if (matchRoute(record$1.regex, location.path, location.params)) {
+ return _createRoute(record$1, location, redirectedFrom)
+ }
+ }
+ }
+ // no match
+ return _createRoute(null, location)
+ }
- var _index72 = _interopRequireDefault(_index71);
+ function redirect (
+ record,
+ location
+ ) {
+ var originalRedirect = record.redirect;
+ var redirect = typeof originalRedirect === 'function'
+ ? originalRedirect(createRoute(record, location, null, router))
+ : originalRedirect;
- var _index73 = __webpack_require__(217);
+ if (typeof redirect === 'string') {
+ redirect = { path: redirect };
+ }
- var _index74 = _interopRequireDefault(_index73);
+ if (!redirect || typeof redirect !== 'object') {
+ if (true) {
+ warn(
+ false, ("invalid redirect option: " + (JSON.stringify(redirect)))
+ );
+ }
+ return _createRoute(null, location)
+ }
- var _index75 = __webpack_require__(225);
+ var re = redirect;
+ var name = re.name;
+ var path = re.path;
+ var query = location.query;
+ var hash = location.hash;
+ var params = location.params;
+ query = re.hasOwnProperty('query') ? re.query : query;
+ hash = re.hasOwnProperty('hash') ? re.hash : hash;
+ params = re.hasOwnProperty('params') ? re.params : params;
- var _index76 = _interopRequireDefault(_index75);
+ if (name) {
+ // resolved named direct
+ var targetRecord = nameMap[name];
+ if (true) {
+ assert(targetRecord, ("redirect failed: named route \"" + name + "\" not found."));
+ }
+ return match({
+ _normalized: true,
+ name: name,
+ query: query,
+ hash: hash,
+ params: params
+ }, undefined, location)
+ } else if (path) {
+ // 1. resolve relative redirect
+ var rawPath = resolveRecordPath(path, record);
+ // 2. resolve params
+ var resolvedPath = fillParams(rawPath, params, ("redirect route with path \"" + rawPath + "\""));
+ // 3. rematch with existing query and hash
+ return match({
+ _normalized: true,
+ path: resolvedPath,
+ query: query,
+ hash: hash
+ }, undefined, location)
+ } else {
+ if (true) {
+ warn(false, ("invalid redirect option: " + (JSON.stringify(redirect))));
+ }
+ return _createRoute(null, location)
+ }
+ }
- var _index77 = __webpack_require__(229);
+ function alias (
+ record,
+ location,
+ matchAs
+ ) {
+ var aliasedPath = fillParams(matchAs, location.params, ("aliased route with path \"" + matchAs + "\""));
+ var aliasedMatch = match({
+ _normalized: true,
+ path: aliasedPath
+ });
+ if (aliasedMatch) {
+ var matched = aliasedMatch.matched;
+ var aliasedRecord = matched[matched.length - 1];
+ location.params = aliasedMatch.params;
+ return _createRoute(aliasedRecord, location)
+ }
+ return _createRoute(null, location)
+ }
- var _index78 = _interopRequireDefault(_index77);
+ function _createRoute (
+ record,
+ location,
+ redirectedFrom
+ ) {
+ if (record && record.redirect) {
+ return redirect(record, redirectedFrom || location)
+ }
+ if (record && record.matchAs) {
+ return alias(record, location, record.matchAs)
+ }
+ return createRoute(record, location, redirectedFrom, router)
+ }
- var _index79 = __webpack_require__(233);
+ return {
+ match: match,
+ addRoutes: addRoutes
+ }
+}
- var _index80 = _interopRequireDefault(_index79);
+function matchRoute (
+ regex,
+ path,
+ params
+) {
+ var m = path.match(regex);
- var _index81 = __webpack_require__(243);
+ if (!m) {
+ return false
+ } else if (!params) {
+ return true
+ }
- var _index82 = _interopRequireDefault(_index81);
+ for (var i = 1, len = m.length; i < len; ++i) {
+ var key = regex.keys[i - 1];
+ var val = typeof m[i] === 'string' ? decodeURIComponent(m[i]) : m[i];
+ if (key) {
+ params[key.name] = val;
+ }
+ }
- var _index83 = __webpack_require__(247);
+ return true
+}
- var _index84 = _interopRequireDefault(_index83);
+function resolveRecordPath (path, record) {
+ return resolvePath(path, record.parent ? record.parent.path : '/', true)
+}
- var _index85 = __webpack_require__(252);
+/* */
- var _index86 = _interopRequireDefault(_index85);
- var _index87 = __webpack_require__(260);
+var positionStore = Object.create(null);
- var _index88 = _interopRequireDefault(_index87);
+function setupScroll () {
+ window.addEventListener('popstate', function (e) {
+ saveScrollPosition();
+ if (e.state && e.state.key) {
+ setStateKey(e.state.key);
+ }
+ });
+}
- var _index89 = __webpack_require__(266);
+function handleScroll (
+ router,
+ to,
+ from,
+ isPop
+) {
+ if (!router.app) {
+ return
+ }
- var _index90 = _interopRequireDefault(_index89);
+ var behavior = router.options.scrollBehavior;
+ if (!behavior) {
+ return
+ }
- var _index91 = __webpack_require__(270);
+ if (true) {
+ assert(typeof behavior === 'function', "scrollBehavior must be a function");
+ }
- var _index92 = _interopRequireDefault(_index91);
+ // wait until re-render finishes before scrolling
+ router.app.$nextTick(function () {
+ var position = getScrollPosition();
+ var shouldScroll = behavior(to, from, isPop ? position : null);
+ if (!shouldScroll) {
+ return
+ }
+ var isObject = typeof shouldScroll === 'object';
+ if (isObject && typeof shouldScroll.selector === 'string') {
+ var el = document.querySelector(shouldScroll.selector);
+ if (el) {
+ var offset = shouldScroll.offset && typeof shouldScroll.offset === 'object' ? shouldScroll.offset : {};
+ offset = normalizeOffset(offset);
+ position = getElementPosition(el, offset);
+ } else if (isValidPosition(shouldScroll)) {
+ position = normalizePosition(shouldScroll);
+ }
+ } else if (isObject && isValidPosition(shouldScroll)) {
+ position = normalizePosition(shouldScroll);
+ }
- var _index93 = __webpack_require__(272);
+ if (position) {
+ window.scrollTo(position.x, position.y);
+ }
+ });
+}
- var _index94 = _interopRequireDefault(_index93);
+function saveScrollPosition () {
+ var key = getStateKey();
+ if (key) {
+ positionStore[key] = {
+ x: window.pageXOffset,
+ y: window.pageYOffset
+ };
+ }
+}
- var _index95 = __webpack_require__(274);
+function getScrollPosition () {
+ var key = getStateKey();
+ if (key) {
+ return positionStore[key]
+ }
+}
- var _index96 = _interopRequireDefault(_index95);
+function getElementPosition (el, offset) {
+ var docEl = document.documentElement;
+ var docRect = docEl.getBoundingClientRect();
+ var elRect = el.getBoundingClientRect();
+ return {
+ x: elRect.left - docRect.left - offset.x,
+ y: elRect.top - docRect.top - offset.y
+ }
+}
- var _index97 = __webpack_require__(290);
+function isValidPosition (obj) {
+ return isNumber(obj.x) || isNumber(obj.y)
+}
- var _index98 = _interopRequireDefault(_index97);
+function normalizePosition (obj) {
+ return {
+ x: isNumber(obj.x) ? obj.x : window.pageXOffset,
+ y: isNumber(obj.y) ? obj.y : window.pageYOffset
+ }
+}
- var _index99 = __webpack_require__(294);
+function normalizeOffset (obj) {
+ return {
+ x: isNumber(obj.x) ? obj.x : 0,
+ y: isNumber(obj.y) ? obj.y : 0
+ }
+}
- var _index100 = _interopRequireDefault(_index99);
+function isNumber (v) {
+ return typeof v === 'number'
+}
- var _index101 = __webpack_require__(298);
+/* */
- var _index102 = _interopRequireDefault(_index101);
+var supportsPushState = inBrowser && (function () {
+ var ua = window.navigator.userAgent;
- var _index103 = __webpack_require__(308);
+ if (
+ (ua.indexOf('Android 2.') !== -1 || ua.indexOf('Android 4.0') !== -1) &&
+ ua.indexOf('Mobile Safari') !== -1 &&
+ ua.indexOf('Chrome') === -1 &&
+ ua.indexOf('Windows Phone') === -1
+ ) {
+ return false
+ }
- var _index104 = _interopRequireDefault(_index103);
+ return window.history && 'pushState' in window.history
+})();
- var _index105 = __webpack_require__(312);
+// use User Timing api (if present) for more accurate key precision
+var Time = inBrowser && window.performance && window.performance.now
+ ? window.performance
+ : Date;
- var _index106 = _interopRequireDefault(_index105);
+var _key = genKey();
- var _index107 = __webpack_require__(316);
+function genKey () {
+ return Time.now().toFixed(3)
+}
- var _index108 = _interopRequireDefault(_index107);
+function getStateKey () {
+ return _key
+}
- var _index109 = __webpack_require__(320);
+function setStateKey (key) {
+ _key = key;
+}
- var _index110 = _interopRequireDefault(_index109);
+function pushState (url, replace) {
+ saveScrollPosition();
+ // try...catch the pushState call to get around Safari
+ // DOM Exception 18 where it limits to 100 pushState calls
+ var history = window.history;
+ try {
+ if (replace) {
+ history.replaceState({ key: _key }, '', url);
+ } else {
+ _key = genKey();
+ history.pushState({ key: _key }, '', url);
+ }
+ } catch (e) {
+ window.location[replace ? 'replace' : 'assign'](url);
+ }
+}
- var _index111 = __webpack_require__(324);
+function replaceState (url) {
+ pushState(url, true);
+}
- var _index112 = _interopRequireDefault(_index111);
+/* */
- var _index113 = __webpack_require__(328);
+function runQueue (queue, fn, cb) {
+ var step = function (index) {
+ if (index >= queue.length) {
+ cb();
+ } else {
+ if (queue[index]) {
+ fn(queue[index], function () {
+ step(index + 1);
+ });
+ } else {
+ step(index + 1);
+ }
+ }
+ };
+ step(0);
+}
- var _index114 = _interopRequireDefault(_index113);
+/* */
- var _index115 = __webpack_require__(332);
+function resolveAsyncComponents (matched) {
+ return function (to, from, next) {
+ var hasAsync = false;
+ var pending = 0;
+ var error = null;
- var _index116 = _interopRequireDefault(_index115);
+ flatMapComponents(matched, function (def, _, match, key) {
+ // if it's a function and doesn't have cid attached,
+ // assume it's an async component resolve function.
+ // we are not using Vue's default async resolving mechanism because
+ // we want to halt the navigation until the incoming component has been
+ // resolved.
+ if (typeof def === 'function' && def.cid === undefined) {
+ hasAsync = true;
+ pending++;
- var _index117 = __webpack_require__(336);
+ var resolve = once(function (resolvedDef) {
+ if (resolvedDef.__esModule && resolvedDef.default) {
+ resolvedDef = resolvedDef.default;
+ }
+ // save resolved on async factory in case it's used elsewhere
+ def.resolved = typeof resolvedDef === 'function'
+ ? resolvedDef
+ : _Vue.extend(resolvedDef);
+ match.components[key] = resolvedDef;
+ pending--;
+ if (pending <= 0) {
+ next();
+ }
+ });
- var _index118 = _interopRequireDefault(_index117);
+ var reject = once(function (reason) {
+ var msg = "Failed to resolve async component " + key + ": " + reason;
+ "development" !== 'production' && warn(false, msg);
+ if (!error) {
+ error = isError(reason)
+ ? reason
+ : new Error(msg);
+ next(error);
+ }
+ });
- var _index119 = __webpack_require__(340);
+ var res;
+ try {
+ res = def(resolve, reject);
+ } catch (e) {
+ reject(e);
+ }
+ if (res) {
+ if (typeof res.then === 'function') {
+ res.then(resolve, reject);
+ } else {
+ // new syntax in Vue 2.3
+ var comp = res.component;
+ if (comp && typeof comp.then === 'function') {
+ comp.then(resolve, reject);
+ }
+ }
+ }
+ }
+ });
- var _index120 = _interopRequireDefault(_index119);
+ if (!hasAsync) { next(); }
+ }
+}
- var _index121 = __webpack_require__(344);
+function flatMapComponents (
+ matched,
+ fn
+) {
+ return flatten(matched.map(function (m) {
+ return Object.keys(m.components).map(function (key) { return fn(
+ m.components[key],
+ m.instances[key],
+ m, key
+ ); })
+ }))
+}
- var _index122 = _interopRequireDefault(_index121);
+function flatten (arr) {
+ return Array.prototype.concat.apply([], arr)
+}
- var _index123 = __webpack_require__(348);
+// in Webpack 2, require.ensure now also returns a Promise
+// so the resolve/reject functions may get called an extra time
+// if the user uses an arrow function shorthand that happens to
+// return that Promise.
+function once (fn) {
+ var called = false;
+ return function () {
+ var args = [], len = arguments.length;
+ while ( len-- ) args[ len ] = arguments[ len ];
- var _index124 = _interopRequireDefault(_index123);
+ if (called) { return }
+ called = true;
+ return fn.apply(this, args)
+ }
+}
- var _index125 = __webpack_require__(356);
+/* */
- var _index126 = _interopRequireDefault(_index125);
+var History = function History (router, base) {
+ this.router = router;
+ this.base = normalizeBase(base);
+ // start with a route object that stands for "nowhere"
+ this.current = START;
+ this.pending = null;
+ this.ready = false;
+ this.readyCbs = [];
+ this.readyErrorCbs = [];
+ this.errorCbs = [];
+};
- var _index127 = __webpack_require__(374);
+History.prototype.listen = function listen (cb) {
+ this.cb = cb;
+};
- var _index128 = _interopRequireDefault(_index127);
+History.prototype.onReady = function onReady (cb, errorCb) {
+ if (this.ready) {
+ cb();
+ } else {
+ this.readyCbs.push(cb);
+ if (errorCb) {
+ this.readyErrorCbs.push(errorCb);
+ }
+ }
+};
- var _locale = __webpack_require__(111);
+History.prototype.onError = function onError (errorCb) {
+ this.errorCbs.push(errorCb);
+};
- var _locale2 = _interopRequireDefault(_locale);
+History.prototype.transitionTo = function transitionTo (location, onComplete, onAbort) {
+ var this$1 = this;
- var _collapseTransition = __webpack_require__(49);
+ var route = this.router.match(location, this.current);
+ this.confirmTransition(route, function () {
+ this$1.updateRoute(route);
+ onComplete && onComplete(route);
+ this$1.ensureURL();
- var _collapseTransition2 = _interopRequireDefault(_collapseTransition);
+ // fire ready cbs once
+ if (!this$1.ready) {
+ this$1.ready = true;
+ this$1.readyCbs.forEach(function (cb) { cb(route); });
+ }
+ }, function (err) {
+ if (onAbort) {
+ onAbort(err);
+ }
+ if (err && !this$1.ready) {
+ this$1.ready = true;
+ this$1.readyErrorCbs.forEach(function (cb) { cb(err); });
+ }
+ });
+};
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+History.prototype.confirmTransition = function confirmTransition (route, onComplete, onAbort) {
+ var this$1 = this;
- /* Automatic generated by './build/bin/build-entry.js' */
+ var current = this.current;
+ var abort = function (err) {
+ if (isError(err)) {
+ if (this$1.errorCbs.length) {
+ this$1.errorCbs.forEach(function (cb) { cb(err); });
+ } else {
+ warn(false, 'uncaught error during route navigation:');
+ console.error(err);
+ }
+ }
+ onAbort && onAbort(err);
+ };
+ if (
+ isSameRoute(route, current) &&
+ // in the case the route map has been dynamically appended to
+ route.matched.length === current.matched.length
+ ) {
+ this.ensureURL();
+ return abort()
+ }
- var components = [_index2.default, _index4.default, _index6.default, _index8.default, _index10.default, _index12.default, _index14.default, _index16.default, _index18.default, _index20.default, _index22.default, _index24.default, _index26.default, _index28.default, _index30.default, _index32.default, _index34.default, _index36.default, _index38.default, _index40.default, _index42.default, _index44.default, _index46.default, _index48.default, _index50.default, _index52.default, _index54.default, _index56.default, _index58.default, _index60.default, _index62.default, _index66.default, _index68.default, _index70.default, _index72.default, _index74.default, _index76.default, _index78.default, _index80.default, _index82.default, _index86.default, _index90.default, _index92.default, _index94.default, _index96.default, _index98.default, _index100.default, _index104.default, _index106.default, _index108.default, _index110.default, _index112.default, _index114.default, _index116.default, _index118.default, _index120.default, _index122.default, _index124.default, _index126.default, _index128.default, _collapseTransition2.default];
+ var ref = resolveQueue(this.current.matched, route.matched);
+ var updated = ref.updated;
+ var deactivated = ref.deactivated;
+ var activated = ref.activated;
- var install = function install(Vue) {
- var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var queue = [].concat(
+ // in-component leave guards
+ extractLeaveGuards(deactivated),
+ // global before hooks
+ this.router.beforeHooks,
+ // in-component update hooks
+ extractUpdateHooks(updated),
+ // in-config enter guards
+ activated.map(function (m) { return m.beforeEnter; }),
+ // async components
+ resolveAsyncComponents(activated)
+ );
- /* istanbul ignore if */
- if (install.installed) return;
- _locale2.default.use(opts.locale);
- _locale2.default.i18n(opts.i18n);
+ this.pending = route;
+ var iterator = function (hook, next) {
+ if (this$1.pending !== route) {
+ return abort()
+ }
+ try {
+ hook(route, current, function (to) {
+ if (to === false || isError(to)) {
+ // next(false) -> abort navigation, ensure current URL
+ this$1.ensureURL(true);
+ abort(to);
+ } else if (
+ typeof to === 'string' ||
+ (typeof to === 'object' && (
+ typeof to.path === 'string' ||
+ typeof to.name === 'string'
+ ))
+ ) {
+ // next('/') or next({ path: '/' }) -> redirect
+ abort();
+ if (typeof to === 'object' && to.replace) {
+ this$1.replace(to);
+ } else {
+ this$1.push(to);
+ }
+ } else {
+ // confirm transition and pass on the value
+ next(to);
+ }
+ });
+ } catch (e) {
+ abort(e);
+ }
+ };
- components.map(function (component) {
- Vue.component(component.name, component);
- });
+ runQueue(queue, iterator, function () {
+ var postEnterCbs = [];
+ var isValid = function () { return this$1.current === route; };
+ // wait until async components are resolved before
+ // extracting in-component enter guards
+ var enterGuards = extractEnterGuards(activated, postEnterCbs, isValid);
+ var queue = enterGuards.concat(this$1.router.resolveHooks);
+ runQueue(queue, iterator, function () {
+ if (this$1.pending !== route) {
+ return abort()
+ }
+ this$1.pending = null;
+ onComplete(route);
+ if (this$1.router.app) {
+ this$1.router.app.$nextTick(function () {
+ postEnterCbs.forEach(function (cb) { cb(); });
+ });
+ }
+ });
+ });
+};
- Vue.use(_index88.default.directive);
+History.prototype.updateRoute = function updateRoute (route) {
+ var prev = this.current;
+ this.current = route;
+ this.cb && this.cb(route);
+ this.router.afterHooks.forEach(function (hook) {
+ hook && hook(route, prev);
+ });
+};
- Vue.prototype.$loading = _index88.default.service;
- Vue.prototype.$msgbox = _index64.default;
- Vue.prototype.$alert = _index64.default.alert;
- Vue.prototype.$confirm = _index64.default.confirm;
- Vue.prototype.$prompt = _index64.default.prompt;
- Vue.prototype.$notify = _index84.default;
- Vue.prototype.$message = _index102.default;
- };
+function normalizeBase (base) {
+ if (!base) {
+ if (inBrowser) {
+ // respect tag
+ var baseEl = document.querySelector('base');
+ base = (baseEl && baseEl.getAttribute('href')) || '/';
+ // strip full URL origin
+ base = base.replace(/^https?:\/\/[^\/]+/, '');
+ } else {
+ base = '/';
+ }
+ }
+ // make sure there's the starting slash
+ if (base.charAt(0) !== '/') {
+ base = '/' + base;
+ }
+ // remove trailing slash
+ return base.replace(/\/$/, '')
+}
- /* istanbul ignore if */
- if (typeof window !== 'undefined' && window.Vue) {
- install(window.Vue);
- };
+function resolveQueue (
+ current,
+ next
+) {
+ var i;
+ var max = Math.max(current.length, next.length);
+ for (i = 0; i < max; i++) {
+ if (current[i] !== next[i]) {
+ break
+ }
+ }
+ return {
+ updated: next.slice(0, i),
+ activated: next.slice(i),
+ deactivated: current.slice(i)
+ }
+}
- module.exports = {
- version: '1.4.4',
- locale: _locale2.default.use,
- i18n: _locale2.default.i18n,
- install: install,
- CollapseTransition: _collapseTransition2.default,
- Loading: _index88.default,
- Pagination: _index2.default,
- Dialog: _index4.default,
- Autocomplete: _index6.default,
- Dropdown: _index8.default,
- DropdownMenu: _index10.default,
- DropdownItem: _index12.default,
- Menu: _index14.default,
- Submenu: _index16.default,
- MenuItem: _index18.default,
- MenuItemGroup: _index20.default,
- Input: _index22.default,
- InputNumber: _index24.default,
- Radio: _index26.default,
- RadioGroup: _index28.default,
- RadioButton: _index30.default,
- Checkbox: _index32.default,
- CheckboxButton: _index34.default,
- CheckboxGroup: _index36.default,
- Switch: _index38.default,
- Select: _index40.default,
- Option: _index42.default,
- OptionGroup: _index44.default,
- Button: _index46.default,
- ButtonGroup: _index48.default,
- Table: _index50.default,
- TableColumn: _index52.default,
- DatePicker: _index54.default,
- TimeSelect: _index56.default,
- TimePicker: _index58.default,
- Popover: _index60.default,
- Tooltip: _index62.default,
- MessageBox: _index64.default,
- Breadcrumb: _index66.default,
- BreadcrumbItem: _index68.default,
- Form: _index70.default,
- FormItem: _index72.default,
- Tabs: _index74.default,
- TabPane: _index76.default,
- Tag: _index78.default,
- Tree: _index80.default,
- Alert: _index82.default,
- Notification: _index84.default,
- Slider: _index86.default,
- Icon: _index90.default,
- Row: _index92.default,
- Col: _index94.default,
- Upload: _index96.default,
- Progress: _index98.default,
- Spinner: _index100.default,
- Message: _index102.default,
- Badge: _index104.default,
- Card: _index106.default,
- Rate: _index108.default,
- Steps: _index110.default,
- Step: _index112.default,
- Carousel: _index114.default,
- Scrollbar: _index116.default,
- CarouselItem: _index118.default,
- Collapse: _index120.default,
- CollapseItem: _index122.default,
- Cascader: _index124.default,
- ColorPicker: _index126.default,
- Transfer: _index128.default
- };
+function extractGuards (
+ records,
+ name,
+ bind,
+ reverse
+) {
+ var guards = flatMapComponents(records, function (def, instance, match, key) {
+ var guard = extractGuard(def, name);
+ if (guard) {
+ return Array.isArray(guard)
+ ? guard.map(function (guard) { return bind(guard, instance, match, key); })
+ : bind(guard, instance, match, key)
+ }
+ });
+ return flatten(reverse ? guards.reverse() : guards)
+}
-/***/ },
-/* 2 */
-/***/ function(module, exports, __webpack_require__) {
+function extractGuard (
+ def,
+ key
+) {
+ if (typeof def !== 'function') {
+ // extend now so that global mixins are applied.
+ def = _Vue.extend(def);
+ }
+ return def.options[key]
+}
- 'use strict';
+function extractLeaveGuards (deactivated) {
+ return extractGuards(deactivated, 'beforeRouteLeave', bindGuard, true)
+}
- exports.__esModule = true;
+function extractUpdateHooks (updated) {
+ return extractGuards(updated, 'beforeRouteUpdate', bindGuard)
+}
- var _pagination = __webpack_require__(3);
+function bindGuard (guard, instance) {
+ if (instance) {
+ return function boundRouteGuard () {
+ return guard.apply(instance, arguments)
+ }
+ }
+}
- var _pagination2 = _interopRequireDefault(_pagination);
+function extractEnterGuards (
+ activated,
+ cbs,
+ isValid
+) {
+ return extractGuards(activated, 'beforeRouteEnter', function (guard, _, match, key) {
+ return bindEnterGuard(guard, match, key, cbs, isValid)
+ })
+}
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+function bindEnterGuard (
+ guard,
+ match,
+ key,
+ cbs,
+ isValid
+) {
+ return function routeEnterGuard (to, from, next) {
+ return guard(to, from, function (cb) {
+ next(cb);
+ if (typeof cb === 'function') {
+ cbs.push(function () {
+ // #750
+ // if a router-view is wrapped with an out-in transition,
+ // the instance may not have been registered at this time.
+ // we will need to poll for registration until current route
+ // is no longer valid.
+ poll(cb, match.instances, key, isValid);
+ });
+ }
+ })
+ }
+}
- /* istanbul ignore next */
- _pagination2.default.install = function (Vue) {
- Vue.component(_pagination2.default.name, _pagination2.default);
- };
+function poll (
+ cb, // somehow flow cannot infer this is a function
+ instances,
+ key,
+ isValid
+) {
+ if (instances[key]) {
+ cb(instances[key]);
+ } else if (isValid()) {
+ setTimeout(function () {
+ poll(cb, instances, key, isValid);
+ }, 16);
+ }
+}
- exports.default = _pagination2.default;
+/* */
-/***/ },
-/* 3 */
-/***/ function(module, exports, __webpack_require__) {
- 'use strict';
+var HTML5History = (function (History$$1) {
+ function HTML5History (router, base) {
+ var this$1 = this;
- exports.__esModule = true;
+ History$$1.call(this, router, base);
- var _pager = __webpack_require__(4);
+ var expectScroll = router.options.scrollBehavior;
- var _pager2 = _interopRequireDefault(_pager);
+ if (expectScroll) {
+ setupScroll();
+ }
- var _select = __webpack_require__(8);
+ window.addEventListener('popstate', function (e) {
+ var current = this$1.current;
+ this$1.transitionTo(getLocation(this$1.base), function (route) {
+ if (expectScroll) {
+ handleScroll(router, route, current, true);
+ }
+ });
+ });
+ }
- var _select2 = _interopRequireDefault(_select);
+ if ( History$$1 ) HTML5History.__proto__ = History$$1;
+ HTML5History.prototype = Object.create( History$$1 && History$$1.prototype );
+ HTML5History.prototype.constructor = HTML5History;
- var _option = __webpack_require__(9);
+ HTML5History.prototype.go = function go (n) {
+ window.history.go(n);
+ };
- var _option2 = _interopRequireDefault(_option);
+ HTML5History.prototype.push = function push (location, onComplete, onAbort) {
+ var this$1 = this;
- var _locale = __webpack_require__(10);
+ var ref = this;
+ var fromRoute = ref.current;
+ this.transitionTo(location, function (route) {
+ pushState(cleanPath(this$1.base + route.fullPath));
+ handleScroll(this$1.router, route, fromRoute, false);
+ onComplete && onComplete(route);
+ }, onAbort);
+ };
- var _locale2 = _interopRequireDefault(_locale);
+ HTML5History.prototype.replace = function replace (location, onComplete, onAbort) {
+ var this$1 = this;
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var ref = this;
+ var fromRoute = ref.current;
+ this.transitionTo(location, function (route) {
+ replaceState(cleanPath(this$1.base + route.fullPath));
+ handleScroll(this$1.router, route, fromRoute, false);
+ onComplete && onComplete(route);
+ }, onAbort);
+ };
- exports.default = {
- name: 'ElPagination',
+ HTML5History.prototype.ensureURL = function ensureURL (push) {
+ if (getLocation(this.base) !== this.current.fullPath) {
+ var current = cleanPath(this.base + this.current.fullPath);
+ push ? pushState(current) : replaceState(current);
+ }
+ };
- props: {
- pageSize: {
- type: Number,
- default: 10
- },
+ HTML5History.prototype.getCurrentLocation = function getCurrentLocation () {
+ return getLocation(this.base)
+ };
- small: Boolean,
+ return HTML5History;
+}(History));
- total: Number,
+function getLocation (base) {
+ var path = window.location.pathname;
+ if (base && path.indexOf(base) === 0) {
+ path = path.slice(base.length);
+ }
+ return (path || '/') + window.location.search + window.location.hash
+}
- pageCount: Number,
+/* */
- currentPage: {
- type: Number,
- default: 1
- },
- layout: {
- default: 'prev, pager, next, jumper, ->, total'
- },
+var HashHistory = (function (History$$1) {
+ function HashHistory (router, base, fallback) {
+ History$$1.call(this, router, base);
+ // check history fallback deeplinking
+ if (fallback && checkFallback(this.base)) {
+ return
+ }
+ ensureSlash();
+ }
- pageSizes: {
- type: Array,
- default: function _default() {
- return [10, 20, 30, 40, 50, 100];
- }
- }
- },
+ if ( History$$1 ) HashHistory.__proto__ = History$$1;
+ HashHistory.prototype = Object.create( History$$1 && History$$1.prototype );
+ HashHistory.prototype.constructor = HashHistory;
- data: function data() {
- return {
- internalCurrentPage: 1,
- internalPageSize: 0
- };
- },
- render: function render(h) {
- var template = h(
- 'div',
- { 'class': 'el-pagination' },
- []
- );
- var layout = this.layout || '';
- if (!layout) return;
- var TEMPLATE_MAP = {
- prev: h(
- 'prev',
- null,
- []
- ),
- jumper: h(
- 'jumper',
- null,
- []
- ),
- pager: h(
- 'pager',
- {
- attrs: { currentPage: this.internalCurrentPage, pageCount: this.internalPageCount },
- on: {
- 'change': this.handleCurrentChange
- }
- },
- []
- ),
- next: h(
- 'next',
- null,
- []
- ),
- sizes: h(
- 'sizes',
- {
- attrs: { pageSizes: this.pageSizes }
- },
- []
- ),
- slot: h(
- 'my-slot',
- null,
- []
- ),
- total: h(
- 'total',
- null,
- []
- )
- };
- var components = layout.split(',').map(function (item) {
- return item.trim();
- });
- var rightWrapper = h(
- 'div',
- { 'class': 'el-pagination__rightwrapper' },
- []
- );
- var haveRightWrapper = false;
+ // this is delayed until the app mounts
+ // to avoid the hashchange listener being fired too early
+ HashHistory.prototype.setupListeners = function setupListeners () {
+ var this$1 = this;
- if (this.small) {
- template.data.class += ' el-pagination--small';
- }
+ window.addEventListener('hashchange', function () {
+ if (!ensureSlash()) {
+ return
+ }
+ this$1.transitionTo(getHash(), function (route) {
+ replaceHash(route.fullPath);
+ });
+ });
+ };
- components.forEach(function (compo) {
- if (compo === '->') {
- haveRightWrapper = true;
- return;
- }
+ HashHistory.prototype.push = function push (location, onComplete, onAbort) {
+ this.transitionTo(location, function (route) {
+ pushHash(route.fullPath);
+ onComplete && onComplete(route);
+ }, onAbort);
+ };
- if (!haveRightWrapper) {
- template.children.push(TEMPLATE_MAP[compo]);
- } else {
- rightWrapper.children.push(TEMPLATE_MAP[compo]);
- }
- });
+ HashHistory.prototype.replace = function replace (location, onComplete, onAbort) {
+ this.transitionTo(location, function (route) {
+ replaceHash(route.fullPath);
+ onComplete && onComplete(route);
+ }, onAbort);
+ };
- if (haveRightWrapper) {
- template.children.unshift(rightWrapper);
- }
+ HashHistory.prototype.go = function go (n) {
+ window.history.go(n);
+ };
- return template;
- },
+ HashHistory.prototype.ensureURL = function ensureURL (push) {
+ var current = this.current.fullPath;
+ if (getHash() !== current) {
+ push ? pushHash(current) : replaceHash(current);
+ }
+ };
+ HashHistory.prototype.getCurrentLocation = function getCurrentLocation () {
+ return getHash()
+ };
- components: {
- MySlot: {
- render: function render(h) {
- return this.$parent.$slots.default ? this.$parent.$slots.default[0] : '';
- }
- },
- Prev: {
- render: function render(h) {
- return h(
- 'button',
- {
- attrs: {
- type: 'button'
- },
- 'class': ['btn-prev', { disabled: this.$parent.internalCurrentPage <= 1 }],
- on: {
- 'click': this.$parent.prev
- }
- },
- [h(
- 'i',
- { 'class': 'el-icon el-icon-arrow-left' },
- []
- )]
- );
- }
- },
+ return HashHistory;
+}(History));
- Next: {
- render: function render(h) {
- return h(
- 'button',
- {
- attrs: {
- type: 'button'
- },
- 'class': ['btn-next', { disabled: this.$parent.internalCurrentPage === this.$parent.internalPageCount || this.$parent.internalPageCount === 0 }],
- on: {
- 'click': this.$parent.next
- }
- },
- [h(
- 'i',
- { 'class': 'el-icon el-icon-arrow-right' },
- []
- )]
- );
- }
- },
+function checkFallback (base) {
+ var location = getLocation(base);
+ if (!/^\/#/.test(location)) {
+ window.location.replace(
+ cleanPath(base + '/#' + location)
+ );
+ return true
+ }
+}
- Sizes: {
- mixins: [_locale2.default],
+function ensureSlash () {
+ var path = getHash();
+ if (path.charAt(0) === '/') {
+ return true
+ }
+ replaceHash('/' + path);
+ return false
+}
- props: {
- pageSizes: Array
- },
+function getHash () {
+ // We can't use window.location.hash here because it's not
+ // consistent across browsers - Firefox will pre-decode it!
+ var href = window.location.href;
+ var index = href.indexOf('#');
+ return index === -1 ? '' : href.slice(index + 1)
+}
- watch: {
- pageSizes: {
- immediate: true,
- handler: function handler(value) {
- if (Array.isArray(value)) {
- this.$parent.internalPageSize = value.indexOf(this.$parent.pageSize) > -1 ? this.$parent.pageSize : this.pageSizes[0];
- }
- }
- }
- },
+function pushHash (path) {
+ window.location.hash = path;
+}
- render: function render(h) {
- var _this = this;
+function replaceHash (path) {
+ var href = window.location.href;
+ var i = href.indexOf('#');
+ var base = i >= 0 ? href.slice(0, i) : href;
+ window.location.replace((base + "#" + path));
+}
- return h(
- 'span',
- { 'class': 'el-pagination__sizes' },
- [h(
- 'el-select',
- {
- attrs: {
- value: this.$parent.internalPageSize
- },
- 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: _select2.default,
- ElOption: _option2.default
- },
+var AbstractHistory = (function (History$$1) {
+ function AbstractHistory (router, base) {
+ History$$1.call(this, router, base);
+ this.stack = [];
+ this.index = -1;
+ }
- methods: {
- handleChange: function handleChange(val) {
- if (val !== this.$parent.internalPageSize) {
- this.$parent.internalPageSize = val = parseInt(val, 10);
- this.$parent.$emit('size-change', val);
- }
- }
- }
- },
+ if ( History$$1 ) AbstractHistory.__proto__ = History$$1;
+ AbstractHistory.prototype = Object.create( History$$1 && History$$1.prototype );
+ AbstractHistory.prototype.constructor = AbstractHistory;
- Jumper: {
- mixins: [_locale2.default],
+ AbstractHistory.prototype.push = function push (location, onComplete, onAbort) {
+ var this$1 = this;
- data: function data() {
- return {
- oldValue: null
- };
- },
+ this.transitionTo(location, function (route) {
+ this$1.stack = this$1.stack.slice(0, this$1.index + 1).concat(route);
+ this$1.index++;
+ onComplete && onComplete(route);
+ }, onAbort);
+ };
+ AbstractHistory.prototype.replace = function replace (location, onComplete, onAbort) {
+ var this$1 = this;
- methods: {
- handleFocus: function handleFocus(event) {
- this.oldValue = event.target.value;
- },
- handleBlur: function handleBlur(_ref) {
- var target = _ref.target;
+ this.transitionTo(location, function (route) {
+ this$1.stack = this$1.stack.slice(0, this$1.index).concat(route);
+ onComplete && onComplete(route);
+ }, onAbort);
+ };
- this.reassignMaxValue(target);
- },
- handleKeyUp: function handleKeyUp(event) {
- var key = event.key || '';
- var keyCode = event.keyCode || '';
- if (key && key === 'Enter' || keyCode && keyCode === 13) {
- this.reassignMaxValue(event.target);
- this.handleChange({ target: event.target });
- }
- },
- handleChange: function handleChange(_ref2) {
- var target = _ref2.target;
+ AbstractHistory.prototype.go = function go (n) {
+ var this$1 = this;
- this.$parent.internalCurrentPage = this.$parent.getValidCurrentPage(target.value);
- this.oldValue = null;
- },
- reassignMaxValue: function reassignMaxValue(target) {
- if (+target.value > this.$parent.internalPageCount) {
- target.value = this.$parent.internalPageCount;
- }
- }
- },
+ var targetIndex = this.index + n;
+ if (targetIndex < 0 || targetIndex >= this.stack.length) {
+ return
+ }
+ var route = this.stack[targetIndex];
+ this.confirmTransition(route, function () {
+ this$1.index = targetIndex;
+ this$1.updateRoute(route);
+ });
+ };
- render: function render(h) {
- return h(
- 'span',
- { 'class': 'el-pagination__jump' },
- [this.t('el.pagination.goto'), h(
- 'input',
- {
- 'class': 'el-pagination__editor',
- attrs: { type: 'number',
- min: 1,
- max: this.$parent.internalPageCount,
- value: this.$parent.internalCurrentPage,
+ AbstractHistory.prototype.getCurrentLocation = function getCurrentLocation () {
+ var current = this.stack[this.stack.length - 1];
+ return current ? current.fullPath : '/'
+ };
- number: true },
- domProps: {
- 'value': this.$parent.internalCurrentPage
- },
- on: {
- 'change': this.handleChange,
- 'focus': this.handleFocus,
- 'blur': this.handleBlur,
- 'keyup': this.handleKeyUp
- }
- },
- []
- ), this.t('el.pagination.pageClassifier')]
- );
- }
- },
+ AbstractHistory.prototype.ensureURL = function ensureURL () {
+ // noop
+ };
- Total: {
- mixins: [_locale2.default],
+ return AbstractHistory;
+}(History));
- 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: _pager2.default
- },
+var VueRouter = function VueRouter (options) {
+ if ( options === void 0 ) options = {};
- methods: {
- handleCurrentChange: function handleCurrentChange(val) {
- this.internalCurrentPage = this.getValidCurrentPage(val);
- },
- prev: function prev() {
- var newVal = this.internalCurrentPage - 1;
- this.internalCurrentPage = this.getValidCurrentPage(newVal);
- },
- next: function next() {
- var newVal = this.internalCurrentPage + 1;
- this.internalCurrentPage = this.getValidCurrentPage(newVal);
- },
- getValidCurrentPage: function getValidCurrentPage(value) {
- value = parseInt(value, 10);
+ this.app = null;
+ this.apps = [];
+ this.options = options;
+ this.beforeHooks = [];
+ this.resolveHooks = [];
+ this.afterHooks = [];
+ this.matcher = createMatcher(options.routes || [], this);
- var havePageCount = typeof this.internalPageCount === 'number';
+ var mode = options.mode || 'hash';
+ this.fallback = mode === 'history' && !supportsPushState && options.fallback !== false;
+ if (this.fallback) {
+ mode = 'hash';
+ }
+ if (!inBrowser) {
+ mode = 'abstract';
+ }
+ this.mode = mode;
- 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;
- }
- }
+ switch (mode) {
+ case 'history':
+ this.history = new HTML5History(this, options.base);
+ break
+ case 'hash':
+ this.history = new HashHistory(this, options.base, this.fallback);
+ break
+ case 'abstract':
+ this.history = new AbstractHistory(this, options.base);
+ break
+ default:
+ if (true) {
+ assert(false, ("invalid mode: " + mode));
+ }
+ }
+};
- if (resetValue === undefined && isNaN(value)) {
- resetValue = 1;
- } else if (resetValue === 0) {
- resetValue = 1;
- }
+var prototypeAccessors = { currentRoute: {} };
- return resetValue === undefined ? value : resetValue;
- }
- },
+VueRouter.prototype.match = function match (
+ raw,
+ current,
+ redirectedFrom
+) {
+ return this.matcher.match(raw, current, redirectedFrom)
+};
- computed: {
- internalPageCount: function internalPageCount() {
- if (typeof this.total === 'number') {
- return Math.ceil(this.total / this.internalPageSize);
- } else if (typeof this.pageCount === 'number') {
- return this.pageCount;
- }
- return null;
- }
- },
+prototypeAccessors.currentRoute.get = function () {
+ return this.history && this.history.current
+};
- watch: {
- currentPage: {
- immediate: true,
- handler: function handler(val) {
- this.internalCurrentPage = val;
- }
- },
+VueRouter.prototype.init = function init (app /* Vue component instance */) {
+ var this$1 = this;
- pageSize: {
- immediate: true,
- handler: function handler(val) {
- this.internalPageSize = val;
- }
- },
+ "development" !== 'production' && assert(
+ install.installed,
+ "not installed. Make sure to call `Vue.use(VueRouter)` " +
+ "before creating root instance."
+ );
- internalCurrentPage: function internalCurrentPage(newVal, oldVal) {
- var _this2 = this;
+ this.apps.push(app);
- newVal = parseInt(newVal, 10);
+ // main app already initialized.
+ if (this.app) {
+ return
+ }
- /* istanbul ignore if */
- if (isNaN(newVal)) {
- newVal = oldVal || 1;
- } else {
- newVal = this.getValidCurrentPage(newVal);
- }
+ this.app = app;
- if (newVal !== undefined) {
- this.$nextTick(function () {
- _this2.internalCurrentPage = newVal;
- if (oldVal !== newVal) {
- _this2.$emit('update:currentPage', newVal);
- _this2.$emit('current-change', _this2.internalCurrentPage);
- }
- });
- } else {
- this.$emit('update:currentPage', newVal);
- this.$emit('current-change', this.internalCurrentPage);
- }
- },
- 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;
- }
- }
- }
- };
+ var history = this.history;
-/***/ },
-/* 4 */
-/***/ function(module, exports, __webpack_require__) {
+ if (history instanceof HTML5History) {
+ history.transitionTo(history.getCurrentLocation());
+ } else if (history instanceof HashHistory) {
+ var setupHashListener = function () {
+ history.setupListeners();
+ };
+ history.transitionTo(
+ history.getCurrentLocation(),
+ setupHashListener,
+ setupHashListener
+ );
+ }
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(6),
- /* template */
- __webpack_require__(7),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ history.listen(function (route) {
+ this$1.apps.forEach(function (app) {
+ app._route = route;
+ });
+ });
+};
- module.exports = Component.exports
+VueRouter.prototype.beforeEach = function beforeEach (fn) {
+ return registerHook(this.beforeHooks, fn)
+};
+VueRouter.prototype.beforeResolve = function beforeResolve (fn) {
+ return registerHook(this.resolveHooks, fn)
+};
-/***/ },
-/* 5 */
-/***/ function(module, exports) {
+VueRouter.prototype.afterEach = function afterEach (fn) {
+ return registerHook(this.afterHooks, fn)
+};
- /* globals __VUE_SSR_CONTEXT__ */
+VueRouter.prototype.onReady = function onReady (cb, errorCb) {
+ this.history.onReady(cb, errorCb);
+};
- // this module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle
+VueRouter.prototype.onError = function onError (errorCb) {
+ this.history.onError(errorCb);
+};
- module.exports = function normalizeComponent (
- rawScriptExports,
- compiledTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier /* server only */
- ) {
- var esModule
- var scriptExports = rawScriptExports = rawScriptExports || {}
+VueRouter.prototype.push = function push (location, onComplete, onAbort) {
+ this.history.push(location, onComplete, onAbort);
+};
- // ES6 modules interop
- var type = typeof rawScriptExports.default
- if (type === 'object' || type === 'function') {
- esModule = rawScriptExports
- scriptExports = rawScriptExports.default
- }
+VueRouter.prototype.replace = function replace (location, onComplete, onAbort) {
+ this.history.replace(location, onComplete, onAbort);
+};
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
+VueRouter.prototype.go = function go (n) {
+ this.history.go(n);
+};
- // render functions
- if (compiledTemplate) {
- options.render = compiledTemplate.render
- options.staticRenderFns = compiledTemplate.staticRenderFns
- }
+VueRouter.prototype.back = function back () {
+ this.go(-1);
+};
- // scopedId
- if (scopeId) {
- options._scopeId = scopeId
- }
+VueRouter.prototype.forward = function forward () {
+ this.go(1);
+};
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context = context || (this.$vnode && this.$vnode.ssrContext)
- // 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 = injectStyles
- }
+VueRouter.prototype.getMatchedComponents = function getMatchedComponents (to) {
+ var route = to
+ ? to.matched
+ ? to
+ : this.resolve(to).route
+ : this.currentRoute;
+ if (!route) {
+ return []
+ }
+ return [].concat.apply([], route.matched.map(function (m) {
+ return Object.keys(m.components).map(function (key) {
+ return m.components[key]
+ })
+ }))
+};
- if (hook) {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
+VueRouter.prototype.resolve = function resolve (
+ to,
+ current,
+ append
+) {
+ var location = normalizeLocation(
+ to,
+ current || this.history.current,
+ append,
+ this
+ );
+ var route = this.match(location, current);
+ var fullPath = route.redirectedFrom || route.fullPath;
+ var base = this.history.base;
+ var href = createHref(base, fullPath, this.mode);
+ return {
+ location: location,
+ route: route,
+ href: href,
+ // for backwards compat
+ normalizedTo: location,
+ resolved: route
+ }
+};
- return {
- esModule: esModule,
- exports: scriptExports,
- options: options
- }
- }
+VueRouter.prototype.addRoutes = function addRoutes (routes) {
+ this.matcher.addRoutes(routes);
+ if (this.history.current !== START) {
+ this.history.transitionTo(this.history.getCurrentLocation());
+ }
+};
+Object.defineProperties( VueRouter.prototype, prototypeAccessors );
-/***/ },
-/* 6 */
-/***/ function(module, exports) {
+function registerHook (list, fn) {
+ list.push(fn);
+ return function () {
+ var i = list.indexOf(fn);
+ if (i > -1) { list.splice(i, 1); }
+ }
+}
- 'use strict';
+function createHref (base, fullPath, mode) {
+ var path = mode === 'hash' ? '#' + fullPath : fullPath;
+ return base ? cleanPath(base + '/' + path) : path
+}
- exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+VueRouter.install = install;
+VueRouter.version = '2.7.0';
- exports.default = {
- name: 'ElPager',
-
- props: {
- currentPage: Number,
-
- pageCount: Number
- },
+if (inBrowser && window.Vue) {
+ window.Vue.use(VueRouter);
+}
- watch: {
- showPrevMore: function showPrevMore(val) {
- if (!val) this.quickprevIconClass = 'el-icon-more';
- },
- showNextMore: function showNextMore(val) {
- if (!val) this.quicknextIconClass = 'el-icon-more';
- }
- },
+/* harmony default export */ __webpack_exports__["default"] = (VueRouter);
- methods: {
- onPagerClick: function onPagerClick(event) {
- var target = event.target;
- if (target.tagName === 'UL') {
- return;
- }
- var newPage = Number(event.target.textContent);
- var pageCount = this.pageCount;
- var currentPage = this.currentPage;
+/***/ }),
+/* 41 */
+/***/ (function(module, exports, __webpack_require__) {
- if (target.className.indexOf('more') !== -1) {
- if (target.className.indexOf('quickprev') !== -1) {
- newPage = currentPage - 5;
- } else if (target.className.indexOf('quicknext') !== -1) {
- newPage = currentPage + 5;
- }
- }
+module.exports =
+/******/ (function(modules) { // webpackBootstrap
+/******/ // The module cache
+/******/ var installedModules = {};
- /* istanbul ignore if */
- if (!isNaN(newPage)) {
- if (newPage < 1) {
- newPage = 1;
- }
+/******/ // The require function
+/******/ function __webpack_require__(moduleId) {
- if (newPage > pageCount) {
- newPage = pageCount;
- }
- }
+/******/ // Check if module is in cache
+/******/ if(installedModules[moduleId])
+/******/ return installedModules[moduleId].exports;
- if (newPage !== currentPage) {
- this.$emit('change', newPage);
- }
- }
- },
+/******/ // Create a new module (and put it into the cache)
+/******/ var module = installedModules[moduleId] = {
+/******/ exports: {},
+/******/ id: moduleId,
+/******/ loaded: false
+/******/ };
- computed: {
- pagers: function pagers() {
- var pagerCount = 7;
+/******/ // Execute the module function
+/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- var currentPage = Number(this.currentPage);
- var pageCount = Number(this.pageCount);
+/******/ // Flag the module as loaded
+/******/ module.loaded = true;
- var showPrevMore = false;
- var showNextMore = false;
+/******/ // Return the exports of the module
+/******/ return module.exports;
+/******/ }
- if (pageCount > pagerCount) {
- if (currentPage > pagerCount - 3) {
- showPrevMore = true;
- }
- if (currentPage < pageCount - 3) {
- showNextMore = true;
- }
- }
+/******/ // expose the modules object (__webpack_modules__)
+/******/ __webpack_require__.m = modules;
- var array = [];
+/******/ // expose the module cache
+/******/ __webpack_require__.c = installedModules;
- 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);
- }
- }
+/******/ // __webpack_public_path__
+/******/ __webpack_require__.p = "/dist/";
- this.showPrevMore = showPrevMore;
- this.showNextMore = showNextMore;
+/******/ // Load entry module and return exports
+/******/ return __webpack_require__(0);
+/******/ })
+/************************************************************************/
+/******/ ([
+/* 0 */
+/***/ function(module, exports, __webpack_require__) {
- return array;
- }
- },
+ module.exports = __webpack_require__(1);
- data: function data() {
- return {
- current: null,
- showPrevMore: false,
- showNextMore: false,
- quicknextIconClass: 'el-icon-more',
- quickprevIconClass: 'el-icon-more'
- };
- }
- };
/***/ },
-/* 7 */
-/***/ function(module, exports) {
+/* 1 */
+/***/ function(module, exports, __webpack_require__) {
- module.exports={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
- }
- }, [_vm._v("1")]) : _vm._e(), (_vm.showPrevMore) ? _c('li', {
- staticClass: "el-icon more btn-quickprev",
- class: [_vm.quickprevIconClass],
- on: {
- "mouseenter": function($event) {
- _vm.quickprevIconClass = 'el-icon-d-arrow-left'
- },
- "mouseleave": function($event) {
- _vm.quickprevIconClass = 'el-icon-more'
- }
- }
- }) : _vm._e(), _vm._l((_vm.pagers), function(pager) {
- return _c('li', {
- staticClass: "number",
- class: {
- active: _vm.currentPage === pager
- }
- }, [_vm._v(_vm._s(pager))])
- }), (_vm.showNextMore) ? _c('li', {
- staticClass: "el-icon more btn-quicknext",
- class: [_vm.quicknextIconClass],
- on: {
- "mouseenter": function($event) {
- _vm.quicknextIconClass = 'el-icon-d-arrow-right'
- },
- "mouseleave": function($event) {
- _vm.quicknextIconClass = 'el-icon-more'
- }
- }
- }) : _vm._e(), (_vm.pageCount > 1) ? _c('li', {
- staticClass: "number",
- class: {
- active: _vm.currentPage === _vm.pageCount
- }
- }, [_vm._v(_vm._s(_vm.pageCount))]) : _vm._e()], 2)
- },staticRenderFns: []}
+ 'use strict';
-/***/ },
-/* 8 */
-/***/ function(module, exports) {
+ var _index = __webpack_require__(2);
- module.exports = __webpack_require__(41);
+ var _index2 = _interopRequireDefault(_index);
-/***/ },
-/* 9 */
-/***/ function(module, exports) {
+ var _index3 = __webpack_require__(11);
- module.exports = __webpack_require__(47);
+ var _index4 = _interopRequireDefault(_index3);
-/***/ },
-/* 10 */
-/***/ function(module, exports) {
+ var _index5 = __webpack_require__(17);
- module.exports = __webpack_require__(24);
+ var _index6 = _interopRequireDefault(_index5);
-/***/ },
-/* 11 */
-/***/ function(module, exports, __webpack_require__) {
+ var _index7 = __webpack_require__(28);
- 'use strict';
+ var _index8 = _interopRequireDefault(_index7);
- exports.__esModule = true;
+ var _index9 = __webpack_require__(33);
- var _component = __webpack_require__(12);
+ var _index10 = _interopRequireDefault(_index9);
- var _component2 = _interopRequireDefault(_component);
+ var _index11 = __webpack_require__(37);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _index12 = _interopRequireDefault(_index11);
- /* istanbul ignore next */
- _component2.default.install = function (Vue) {
- Vue.component(_component2.default.name, _component2.default);
- };
+ var _index13 = __webpack_require__(41);
- exports.default = _component2.default;
+ var _index14 = _interopRequireDefault(_index13);
-/***/ },
-/* 12 */
-/***/ function(module, exports, __webpack_require__) {
+ var _index15 = __webpack_require__(46);
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(13),
- /* template */
- __webpack_require__(16),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ var _index16 = _interopRequireDefault(_index15);
- module.exports = Component.exports
+ var _index17 = __webpack_require__(52);
+ var _index18 = _interopRequireDefault(_index17);
-/***/ },
-/* 13 */
-/***/ function(module, exports, __webpack_require__) {
+ var _index19 = __webpack_require__(56);
- 'use strict';
+ var _index20 = _interopRequireDefault(_index19);
- exports.__esModule = true;
+ var _index21 = __webpack_require__(60);
- var _popup = __webpack_require__(14);
+ var _index22 = _interopRequireDefault(_index21);
- var _popup2 = _interopRequireDefault(_popup);
+ var _index23 = __webpack_require__(66);
- var _emitter = __webpack_require__(15);
+ var _index24 = _interopRequireDefault(_index23);
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _index25 = __webpack_require__(71);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _index26 = _interopRequireDefault(_index25);
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ var _index27 = __webpack_require__(75);
- exports.default = {
- name: 'ElDialog',
+ var _index28 = _interopRequireDefault(_index27);
- mixins: [_popup2.default, _emitter2.default],
+ var _index29 = __webpack_require__(79);
- props: {
- title: {
- type: String,
- default: ''
- },
+ var _index30 = _interopRequireDefault(_index29);
- modal: {
- type: Boolean,
- default: true
- },
+ var _index31 = __webpack_require__(83);
- modalAppendToBody: {
- type: Boolean,
- default: true
- },
+ var _index32 = _interopRequireDefault(_index31);
- lockScroll: {
- type: Boolean,
- default: true
- },
+ var _index33 = __webpack_require__(87);
- closeOnClickModal: {
- type: Boolean,
- default: true
- },
+ var _index34 = _interopRequireDefault(_index33);
- closeOnPressEscape: {
- type: Boolean,
- default: true
- },
+ var _index35 = __webpack_require__(91);
- showClose: {
- type: Boolean,
- default: true
- },
+ var _index36 = _interopRequireDefault(_index35);
- size: {
- type: String,
- default: 'small'
- },
+ var _index37 = __webpack_require__(95);
- customClass: {
- type: String,
- default: ''
- },
+ var _index38 = _interopRequireDefault(_index37);
- top: {
- type: String,
- default: '15%'
- },
- beforeClose: Function
- },
+ var _index39 = __webpack_require__(99);
- watch: {
- visible: function visible(val) {
- var _this = this;
+ var _index40 = _interopRequireDefault(_index39);
- this.$emit('update:visible', val);
- if (val) {
- this.$emit('open');
- this.$el.addEventListener('scroll', this.updatePopper);
- this.$nextTick(function () {
- _this.$refs.dialog.scrollTop = 0;
- });
- } else {
- this.$el.removeEventListener('scroll', this.updatePopper);
- this.$emit('close');
- }
- }
- },
+ var _index41 = __webpack_require__(114);
- computed: {
- sizeClass: function sizeClass() {
- return 'el-dialog--' + this.size;
- },
- style: function style() {
- return this.size === 'full' ? {} : { 'top': this.top };
- }
- },
+ var _index42 = _interopRequireDefault(_index41);
- methods: {
- 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('visible-change', false);
- }
- },
- updatePopper: function updatePopper() {
- this.broadcast('ElSelectDropdown', 'updatePopper');
- this.broadcast('ElDropdownMenu', 'updatePopper');
- }
- },
+ var _index43 = __webpack_require__(115);
- mounted: function mounted() {
- if (this.visible) {
- this.rendered = true;
- this.open();
- }
- }
- };
+ var _index44 = _interopRequireDefault(_index43);
-/***/ },
-/* 14 */
-/***/ function(module, exports) {
+ var _index45 = __webpack_require__(119);
- module.exports = __webpack_require__(21);
+ var _index46 = _interopRequireDefault(_index45);
-/***/ },
-/* 15 */
-/***/ function(module, exports) {
+ var _index47 = __webpack_require__(123);
- module.exports = __webpack_require__(5);
+ var _index48 = _interopRequireDefault(_index47);
-/***/ },
-/* 16 */
-/***/ function(module, exports) {
+ var _index49 = __webpack_require__(127);
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('transition', {
- attrs: {
- "name": "dialog-fade"
- }
- }, [_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; }
- _vm.handleWrapperClick($event)
- }
- }
- }, [_c('div', {
- ref: "dialog",
- staticClass: "el-dialog",
- class: [_vm.sizeClass, _vm.customClass],
- style: (_vm.style)
- }, [_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()])])])
- },staticRenderFns: []}
+ var _index50 = _interopRequireDefault(_index49);
-/***/ },
-/* 17 */
-/***/ function(module, exports, __webpack_require__) {
+ var _index51 = __webpack_require__(147);
- 'use strict';
+ var _index52 = _interopRequireDefault(_index51);
- exports.__esModule = true;
+ var _index53 = __webpack_require__(149);
- var _autocomplete = __webpack_require__(18);
+ var _index54 = _interopRequireDefault(_index53);
- var _autocomplete2 = _interopRequireDefault(_autocomplete);
+ var _index55 = __webpack_require__(177);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _index56 = _interopRequireDefault(_index55);
- /* istanbul ignore next */
- _autocomplete2.default.install = function (Vue) {
- Vue.component(_autocomplete2.default.name, _autocomplete2.default);
- };
+ var _index57 = __webpack_require__(182);
- exports.default = _autocomplete2.default;
+ var _index58 = _interopRequireDefault(_index57);
-/***/ },
-/* 18 */
-/***/ function(module, exports, __webpack_require__) {
+ var _index59 = __webpack_require__(187);
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(19),
- /* template */
- __webpack_require__(27),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ var _index60 = _interopRequireDefault(_index59);
- module.exports = Component.exports
+ var _index61 = __webpack_require__(192);
+ var _index62 = _interopRequireDefault(_index61);
-/***/ },
-/* 19 */
-/***/ function(module, exports, __webpack_require__) {
+ var _index63 = __webpack_require__(195);
- 'use strict';
+ var _index64 = _interopRequireDefault(_index63);
- exports.__esModule = true;
+ var _index65 = __webpack_require__(200);
- var _input = __webpack_require__(20);
+ var _index66 = _interopRequireDefault(_index65);
- var _input2 = _interopRequireDefault(_input);
+ var _index67 = __webpack_require__(204);
- var _clickoutside = __webpack_require__(21);
+ var _index68 = _interopRequireDefault(_index67);
- var _clickoutside2 = _interopRequireDefault(_clickoutside);
+ var _index69 = __webpack_require__(208);
- var _autocompleteSuggestions = __webpack_require__(22);
+ var _index70 = _interopRequireDefault(_index69);
- var _autocompleteSuggestions2 = _interopRequireDefault(_autocompleteSuggestions);
+ var _index71 = __webpack_require__(212);
- var _emitter = __webpack_require__(15);
+ var _index72 = _interopRequireDefault(_index71);
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _index73 = __webpack_require__(217);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _index74 = _interopRequireDefault(_index73);
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ var _index75 = __webpack_require__(225);
- exports.default = {
- name: 'ElAutocomplete',
+ var _index76 = _interopRequireDefault(_index75);
- mixins: [_emitter2.default],
+ var _index77 = __webpack_require__(229);
- componentName: 'ElAutocomplete',
+ var _index78 = _interopRequireDefault(_index77);
- components: {
- ElInput: _input2.default,
- ElAutocompleteSuggestions: _autocompleteSuggestions2.default
- },
+ var _index79 = __webpack_require__(233);
- directives: { Clickoutside: _clickoutside2.default },
+ var _index80 = _interopRequireDefault(_index79);
- props: {
- props: {
- type: Object,
- default: function _default() {
- return {
- label: 'value',
- value: 'value'
- };
- }
- },
- popperClass: String,
- placeholder: String,
- disabled: Boolean,
- name: String,
- size: String,
- value: String,
- autofocus: Boolean,
- fetchSuggestions: Function,
- triggerOnFocus: {
- type: Boolean,
- default: true
- },
- customItem: String,
- icon: String,
- onIconClick: Function
- },
- data: function data() {
- return {
- activated: false,
- isOnComposition: false,
- suggestions: [],
- loading: false,
- highlightedIndex: -1
- };
- },
+ var _index81 = __webpack_require__(243);
- computed: {
- suggestionVisible: function suggestionVisible() {
- var suggestions = this.suggestions;
- var isValidData = Array.isArray(suggestions) && suggestions.length > 0;
- return (isValidData || this.loading) && this.activated;
- }
- },
- watch: {
- suggestionVisible: function suggestionVisible(val) {
- this.broadcast('ElAutocompleteSuggestions', 'visible', [val, this.$refs.input.$refs.input.offsetWidth]);
- }
- },
- methods: {
- getData: function getData(queryString) {
- var _this = this;
+ var _index82 = _interopRequireDefault(_index81);
- this.loading = true;
- this.fetchSuggestions(queryString, function (suggestions) {
- _this.loading = false;
- if (Array.isArray(suggestions)) {
- _this.suggestions = suggestions;
- } else {
- console.error('autocomplete suggestions must be an array');
- }
- });
- },
- handleComposition: function handleComposition(event) {
- if (event.type === 'compositionend') {
- this.isOnComposition = false;
- this.handleChange(this.value);
- } else {
- this.isOnComposition = true;
- }
- },
- handleChange: function handleChange(value) {
- this.$emit('input', value);
- if (this.isOnComposition || !this.triggerOnFocus && !value) {
- this.suggestions = [];
- return;
- }
- this.getData(value);
- },
- handleFocus: function handleFocus() {
- this.activated = true;
- if (this.triggerOnFocus) {
- this.getData(this.value);
- }
- },
- close: function close(e) {
- this.activated = false;
- },
- handleKeyEnter: function handleKeyEnter(e) {
- if (this.suggestionVisible && this.highlightedIndex >= 0 && this.highlightedIndex < this.suggestions.length) {
- e.preventDefault();
- this.select(this.suggestions[this.highlightedIndex]);
- }
- },
- select: function select(item) {
- var _this2 = this;
+ var _index83 = __webpack_require__(247);
- this.$emit('input', item[this.props.value]);
- this.$emit('select', item);
- this.$nextTick(function (_) {
- _this2.suggestions = [];
- });
- },
- highlight: function highlight(index) {
- if (!this.suggestionVisible || this.loading) {
- return;
- }
- if (index < 0) index = 0;
- 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 _index84 = _interopRequireDefault(_index83);
- var highlightItem = suggestionList[index];
- var scrollTop = suggestion.scrollTop;
- var offsetTop = highlightItem.offsetTop;
+ var _index85 = __webpack_require__(252);
- if (offsetTop + highlightItem.scrollHeight > scrollTop + suggestion.clientHeight) {
- suggestion.scrollTop += highlightItem.scrollHeight;
- }
- if (offsetTop < scrollTop) {
- suggestion.scrollTop -= highlightItem.scrollHeight;
- }
+ var _index86 = _interopRequireDefault(_index85);
- this.highlightedIndex = index;
- }
- },
- mounted: function mounted() {
- var _this3 = this;
+ var _index87 = __webpack_require__(260);
- this.$on('item-click', function (item) {
- _this3.select(item);
- });
- },
- beforeDestroy: function beforeDestroy() {
- this.$refs.suggestions.$destroy();
- }
- };
+ var _index88 = _interopRequireDefault(_index87);
-/***/ },
-/* 20 */
-/***/ function(module, exports) {
+ var _index89 = __webpack_require__(266);
- module.exports = __webpack_require__(11);
+ var _index90 = _interopRequireDefault(_index89);
-/***/ },
-/* 21 */
-/***/ function(module, exports) {
+ var _index91 = __webpack_require__(270);
- module.exports = __webpack_require__(20);
+ var _index92 = _interopRequireDefault(_index91);
-/***/ },
-/* 22 */
-/***/ function(module, exports, __webpack_require__) {
+ var _index93 = __webpack_require__(272);
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(23),
- /* template */
- __webpack_require__(26),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ var _index94 = _interopRequireDefault(_index93);
- module.exports = Component.exports
+ var _index95 = __webpack_require__(274);
+ var _index96 = _interopRequireDefault(_index95);
-/***/ },
-/* 23 */
-/***/ function(module, exports, __webpack_require__) {
+ var _index97 = __webpack_require__(290);
- 'use strict';
+ var _index98 = _interopRequireDefault(_index97);
- exports.__esModule = true;
+ var _index99 = __webpack_require__(294);
- var _vuePopper = __webpack_require__(24);
+ var _index100 = _interopRequireDefault(_index99);
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
+ var _index101 = __webpack_require__(298);
- var _emitter = __webpack_require__(15);
+ var _index102 = _interopRequireDefault(_index101);
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _index103 = __webpack_require__(308);
- var _scrollbar = __webpack_require__(25);
+ var _index104 = _interopRequireDefault(_index103);
- var _scrollbar2 = _interopRequireDefault(_scrollbar);
+ var _index105 = __webpack_require__(312);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _index106 = _interopRequireDefault(_index105);
- exports.default = {
- components: { ElScrollbar: _scrollbar2.default },
- mixins: [_vuePopper2.default, _emitter2.default],
+ var _index107 = __webpack_require__(316);
- componentName: 'ElAutocompleteSuggestions',
+ var _index108 = _interopRequireDefault(_index107);
- data: function data() {
- return {
- parent: this.$parent,
- dropdownWidth: ''
- };
- },
+ var _index109 = __webpack_require__(320);
+ var _index110 = _interopRequireDefault(_index109);
- props: {
- props: Object,
- suggestions: Array,
- options: {
- default: function _default() {
- return {
- forceAbsolute: true,
- gpuAcceleration: false
- };
- }
- }
- },
+ var _index111 = __webpack_require__(324);
- methods: {
- select: function select(item) {
- this.dispatch('ElAutocomplete', 'item-click', item);
- }
- },
+ var _index112 = _interopRequireDefault(_index111);
- updated: function updated() {
- var _this = this;
+ var _index113 = __webpack_require__(328);
- this.$nextTick(function (_) {
- _this.updatePopper();
- });
- },
- mounted: function mounted() {
- this.$parent.popperElm = this.popperElm = this.$el;
- this.referenceElm = this.$parent.$refs.input.$refs.input;
- },
- created: function created() {
- var _this2 = this;
+ var _index114 = _interopRequireDefault(_index113);
- this.$on('visible', function (val, inputWidth) {
- _this2.dropdownWidth = inputWidth + 'px';
- _this2.showPopper = val;
- });
- }
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ var _index115 = __webpack_require__(332);
-/***/ },
-/* 24 */
-/***/ function(module, exports) {
+ var _index116 = _interopRequireDefault(_index115);
- module.exports = __webpack_require__(13);
+ var _index117 = __webpack_require__(336);
-/***/ },
-/* 25 */
-/***/ function(module, exports) {
+ var _index118 = _interopRequireDefault(_index117);
- module.exports = __webpack_require__(22);
+ var _index119 = __webpack_require__(340);
-/***/ },
-/* 26 */
-/***/ function(module, exports) {
+ var _index120 = _interopRequireDefault(_index119);
- module.exports={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",
- class: {
- 'is-loading': _vm.parent.loading
- },
- style: ({
- width: _vm.dropdownWidth
- })
- }, [_c('el-scrollbar', {
- attrs: {
- "tag": "ul",
- "wrap-class": "el-autocomplete-suggestion__wrap",
- "view-class": "el-autocomplete-suggestion__list"
- }
- }, [(_vm.parent.loading) ? _c('li', [_c('i', {
- staticClass: "el-icon-loading"
- })]) : _vm._l((_vm.suggestions), function(item, index) {
- return [(!_vm.parent.customItem) ? _c('li', {
- class: {
- 'highlighted': _vm.parent.highlightedIndex === index
- },
- on: {
- "click": function($event) {
- _vm.select(item)
- }
- }
- }, [_vm._v("\n " + _vm._s(item[_vm.props.label]) + "\n ")]) : _c(_vm.parent.customItem, {
- tag: "component",
- class: {
- 'highlighted': _vm.parent.highlightedIndex === index
- },
- attrs: {
- "item": item,
- "index": index
- },
- on: {
- "click": function($event) {
- _vm.select(item)
- }
- }
- })]
- })], 2)], 1)])
- },staticRenderFns: []}
+ var _index121 = __webpack_require__(344);
-/***/ },
-/* 27 */
-/***/ function(module, exports) {
+ var _index122 = _interopRequireDefault(_index121);
- module.exports={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"
- }, [_c('el-input', _vm._b({
- ref: "input",
- on: {
- "change": _vm.handleChange,
- "focus": _vm.handleFocus
- },
- nativeOn: {
- "compositionstart": function($event) {
- _vm.handleComposition($event)
- },
- "compositionupdate": function($event) {
- _vm.handleComposition($event)
- },
- "compositionend": function($event) {
- _vm.handleComposition($event)
- },
- "keydown": [function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
- $event.preventDefault();
- _vm.highlight(_vm.highlightedIndex - 1)
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
- $event.preventDefault();
- _vm.highlight(_vm.highlightedIndex + 1)
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
- _vm.handleKeyEnter($event)
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "tab", 9)) { return null; }
- _vm.close($event)
- }]
- }
- }, 'el-input', _vm.$props), [(_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()], 2), _c('el-autocomplete-suggestions', {
- ref: "suggestions",
- class: [_vm.popperClass ? _vm.popperClass : ''],
- attrs: {
- "props": _vm.props,
- "suggestions": _vm.suggestions
- }
- })], 1)
- },staticRenderFns: []}
+ var _index123 = __webpack_require__(348);
-/***/ },
-/* 28 */
-/***/ function(module, exports, __webpack_require__) {
+ var _index124 = _interopRequireDefault(_index123);
- 'use strict';
+ var _index125 = __webpack_require__(356);
- exports.__esModule = true;
+ var _index126 = _interopRequireDefault(_index125);
- var _dropdown = __webpack_require__(29);
+ var _index127 = __webpack_require__(374);
- var _dropdown2 = _interopRequireDefault(_dropdown);
+ var _index128 = _interopRequireDefault(_index127);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _locale = __webpack_require__(111);
- /* istanbul ignore next */
- _dropdown2.default.install = function (Vue) {
- Vue.component(_dropdown2.default.name, _dropdown2.default);
- };
+ var _locale2 = _interopRequireDefault(_locale);
- exports.default = _dropdown2.default;
+ var _collapseTransition = __webpack_require__(49);
-/***/ },
-/* 29 */
-/***/ function(module, exports, __webpack_require__) {
+ var _collapseTransition2 = _interopRequireDefault(_collapseTransition);
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(30),
- /* template */
- null,
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- module.exports = Component.exports
+ /* Automatic generated by './build/bin/build-entry.js' */
+
+ var components = [_index2.default, _index4.default, _index6.default, _index8.default, _index10.default, _index12.default, _index14.default, _index16.default, _index18.default, _index20.default, _index22.default, _index24.default, _index26.default, _index28.default, _index30.default, _index32.default, _index34.default, _index36.default, _index38.default, _index40.default, _index42.default, _index44.default, _index46.default, _index48.default, _index50.default, _index52.default, _index54.default, _index56.default, _index58.default, _index60.default, _index62.default, _index66.default, _index68.default, _index70.default, _index72.default, _index74.default, _index76.default, _index78.default, _index80.default, _index82.default, _index86.default, _index90.default, _index92.default, _index94.default, _index96.default, _index98.default, _index100.default, _index104.default, _index106.default, _index108.default, _index110.default, _index112.default, _index114.default, _index116.default, _index118.default, _index120.default, _index122.default, _index124.default, _index126.default, _index128.default, _collapseTransition2.default];
+
+ var install = function install(Vue) {
+ var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+
+ /* istanbul ignore if */
+ if (install.installed) return;
+ _locale2.default.use(opts.locale);
+ _locale2.default.i18n(opts.i18n);
+
+ components.map(function (component) {
+ Vue.component(component.name, component);
+ });
+
+ Vue.use(_index88.default.directive);
+
+ Vue.prototype.$loading = _index88.default.service;
+ Vue.prototype.$msgbox = _index64.default;
+ Vue.prototype.$alert = _index64.default.alert;
+ Vue.prototype.$confirm = _index64.default.confirm;
+ Vue.prototype.$prompt = _index64.default.prompt;
+ Vue.prototype.$notify = _index84.default;
+ Vue.prototype.$message = _index102.default;
+ };
+
+ /* istanbul ignore if */
+ if (typeof window !== 'undefined' && window.Vue) {
+ install(window.Vue);
+ };
+ module.exports = {
+ version: '1.4.4',
+ locale: _locale2.default.use,
+ i18n: _locale2.default.i18n,
+ install: install,
+ CollapseTransition: _collapseTransition2.default,
+ Loading: _index88.default,
+ Pagination: _index2.default,
+ Dialog: _index4.default,
+ Autocomplete: _index6.default,
+ Dropdown: _index8.default,
+ DropdownMenu: _index10.default,
+ DropdownItem: _index12.default,
+ Menu: _index14.default,
+ Submenu: _index16.default,
+ MenuItem: _index18.default,
+ MenuItemGroup: _index20.default,
+ Input: _index22.default,
+ InputNumber: _index24.default,
+ Radio: _index26.default,
+ RadioGroup: _index28.default,
+ RadioButton: _index30.default,
+ Checkbox: _index32.default,
+ CheckboxButton: _index34.default,
+ CheckboxGroup: _index36.default,
+ Switch: _index38.default,
+ Select: _index40.default,
+ Option: _index42.default,
+ OptionGroup: _index44.default,
+ Button: _index46.default,
+ ButtonGroup: _index48.default,
+ Table: _index50.default,
+ TableColumn: _index52.default,
+ DatePicker: _index54.default,
+ TimeSelect: _index56.default,
+ TimePicker: _index58.default,
+ Popover: _index60.default,
+ Tooltip: _index62.default,
+ MessageBox: _index64.default,
+ Breadcrumb: _index66.default,
+ BreadcrumbItem: _index68.default,
+ Form: _index70.default,
+ FormItem: _index72.default,
+ Tabs: _index74.default,
+ TabPane: _index76.default,
+ Tag: _index78.default,
+ Tree: _index80.default,
+ Alert: _index82.default,
+ Notification: _index84.default,
+ Slider: _index86.default,
+ Icon: _index90.default,
+ Row: _index92.default,
+ Col: _index94.default,
+ Upload: _index96.default,
+ Progress: _index98.default,
+ Spinner: _index100.default,
+ Message: _index102.default,
+ Badge: _index104.default,
+ Card: _index106.default,
+ Rate: _index108.default,
+ Steps: _index110.default,
+ Step: _index112.default,
+ Carousel: _index114.default,
+ Scrollbar: _index116.default,
+ CarouselItem: _index118.default,
+ Collapse: _index120.default,
+ CollapseItem: _index122.default,
+ Cascader: _index124.default,
+ ColorPicker: _index126.default,
+ Transfer: _index128.default
+ };
/***/ },
-/* 30 */
+/* 2 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _clickoutside = __webpack_require__(21);
+ var _pagination = __webpack_require__(3);
- var _clickoutside2 = _interopRequireDefault(_clickoutside);
+ var _pagination2 = _interopRequireDefault(_pagination);
- var _emitter = __webpack_require__(15);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var _emitter2 = _interopRequireDefault(_emitter);
+ /* istanbul ignore next */
+ _pagination2.default.install = function (Vue) {
+ Vue.component(_pagination2.default.name, _pagination2.default);
+ };
- var _button = __webpack_require__(31);
+ exports.default = _pagination2.default;
- var _button2 = _interopRequireDefault(_button);
+/***/ },
+/* 3 */
+/***/ function(module, exports, __webpack_require__) {
- var _buttonGroup = __webpack_require__(32);
+ 'use strict';
- var _buttonGroup2 = _interopRequireDefault(_buttonGroup);
+ exports.__esModule = true;
+
+ var _pager = __webpack_require__(4);
+
+ var _pager2 = _interopRequireDefault(_pager);
+
+ var _select = __webpack_require__(8);
+
+ var _select2 = _interopRequireDefault(_select);
+
+ var _option = __webpack_require__(9);
+
+ var _option2 = _interopRequireDefault(_option);
+
+ var _locale = __webpack_require__(10);
+
+ var _locale2 = _interopRequireDefault(_locale);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElDropdown',
+ name: 'ElPagination',
- componentName: 'ElDropdown',
+ props: {
+ pageSize: {
+ type: Number,
+ default: 10
+ },
- mixins: [_emitter2.default],
+ small: Boolean,
- directives: { Clickoutside: _clickoutside2.default },
+ total: Number,
- components: {
- ElButton: _button2.default,
- ElButtonGroup: _buttonGroup2.default
- },
+ pageCount: Number,
- props: {
- trigger: {
- type: String,
- default: 'hover'
+ currentPage: {
+ type: Number,
+ default: 1
},
- menuAlign: {
- type: String,
- default: 'end'
+
+ layout: {
+ default: 'prev, pager, next, jumper, ->, total'
},
- type: String,
- size: String,
- splitButton: Boolean,
- hideOnClick: {
- type: Boolean,
- default: true
+
+ pageSizes: {
+ type: Array,
+ default: function _default() {
+ return [10, 20, 30, 40, 50, 100];
+ }
}
},
data: function data() {
return {
- timeout: null,
- visible: false
+ internalCurrentPage: 1,
+ internalPageSize: 0
};
},
- mounted: function mounted() {
- this.$on('menu-item-click', this.handleMenuItemClick);
- this.initEvent();
- },
-
+ render: function render(h) {
+ var template = h(
+ 'div',
+ { 'class': 'el-pagination' },
+ []
+ );
+ var layout = this.layout || '';
+ if (!layout) return;
+ var TEMPLATE_MAP = {
+ prev: h(
+ 'prev',
+ null,
+ []
+ ),
+ jumper: h(
+ 'jumper',
+ null,
+ []
+ ),
+ pager: h(
+ 'pager',
+ {
+ attrs: { currentPage: this.internalCurrentPage, pageCount: this.internalPageCount },
+ on: {
+ 'change': this.handleCurrentChange
+ }
+ },
+ []
+ ),
+ next: h(
+ 'next',
+ null,
+ []
+ ),
+ sizes: h(
+ 'sizes',
+ {
+ attrs: { pageSizes: this.pageSizes }
+ },
+ []
+ ),
+ slot: h(
+ 'my-slot',
+ null,
+ []
+ ),
+ total: h(
+ 'total',
+ null,
+ []
+ )
+ };
+ var components = layout.split(',').map(function (item) {
+ return item.trim();
+ });
+ var rightWrapper = h(
+ 'div',
+ { 'class': 'el-pagination__rightwrapper' },
+ []
+ );
+ var haveRightWrapper = false;
- watch: {
- visible: function visible(val) {
- this.broadcast('ElDropdownMenu', 'visible', val);
- this.$emit('visible-change', val);
+ if (this.small) {
+ template.data.class += ' el-pagination--small';
}
- },
-
- methods: {
- show: function show() {
- var _this = this;
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this.visible = true;
- }, 250);
- },
- hide: function hide() {
- var _this2 = this;
+ components.forEach(function (compo) {
+ if (compo === '->') {
+ haveRightWrapper = true;
+ return;
+ }
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this2.visible = false;
- }, 150);
- },
- handleClick: function handleClick() {
- this.visible = !this.visible;
- },
- initEvent: function initEvent() {
- var trigger = this.trigger,
- show = this.show,
- hide = this.hide,
- handleClick = this.handleClick,
- splitButton = this.splitButton;
+ if (!haveRightWrapper) {
+ template.children.push(TEMPLATE_MAP[compo]);
+ } else {
+ rightWrapper.children.push(TEMPLATE_MAP[compo]);
+ }
+ });
- var triggerElm = splitButton ? this.$refs.trigger.$el : this.$slots.default[0].elm;
+ if (haveRightWrapper) {
+ template.children.unshift(rightWrapper);
+ }
- if (triggerElm.disabled) return;
- if (trigger === 'hover') {
- triggerElm.addEventListener('mouseenter', show);
- triggerElm.addEventListener('mouseleave', hide);
+ return template;
+ },
- var dropdownElm = this.$slots.dropdown[0].elm;
- dropdownElm.addEventListener('mouseenter', show);
- dropdownElm.addEventListener('mouseleave', hide);
- } else if (trigger === 'click') {
- triggerElm.addEventListener('click', handleClick);
+ components: {
+ MySlot: {
+ render: function render(h) {
+ return this.$parent.$slots.default ? this.$parent.$slots.default[0] : '';
}
},
- handleMenuItemClick: function handleMenuItemClick(command, instance) {
- if (this.hideOnClick) {
- this.visible = false;
+ Prev: {
+ render: function render(h) {
+ return h(
+ 'button',
+ {
+ attrs: {
+ type: 'button'
+ },
+ 'class': ['btn-prev', { disabled: this.$parent.internalCurrentPage <= 1 }],
+ on: {
+ 'click': this.$parent.prev
+ }
+ },
+ [h(
+ 'i',
+ { 'class': 'el-icon el-icon-arrow-left' },
+ []
+ )]
+ );
}
- this.$emit('command', command, instance);
- }
- },
-
- render: function render(h) {
- var _this3 = this;
+ },
- var hide = this.hide,
- splitButton = this.splitButton,
- type = this.type,
- size = this.size;
+ Next: {
+ render: function render(h) {
+ return h(
+ 'button',
+ {
+ attrs: {
+ type: 'button'
+ },
+ 'class': ['btn-next', { disabled: this.$parent.internalCurrentPage === this.$parent.internalPageCount || this.$parent.internalPageCount === 0 }],
+ on: {
+ 'click': this.$parent.next
+ }
+ },
+ [h(
+ 'i',
+ { 'class': 'el-icon el-icon-arrow-right' },
+ []
+ )]
+ );
+ }
+ },
+ Sizes: {
+ mixins: [_locale2.default],
- var handleClick = function handleClick(_) {
- _this3.$emit('click');
- };
+ props: {
+ pageSizes: Array
+ },
- var triggerElm = !splitButton ? this.$slots.default : h(
- 'el-button-group',
- null,
- [h(
- 'el-button',
- {
- attrs: { type: type, size: size },
- nativeOn: {
- 'click': handleClick
+ watch: {
+ pageSizes: {
+ immediate: true,
+ handler: function handler(value) {
+ if (Array.isArray(value)) {
+ this.$parent.internalPageSize = value.indexOf(this.$parent.pageSize) > -1 ? this.$parent.pageSize : this.pageSizes[0];
+ }
}
- },
- [this.$slots.default]
- ), h(
- 'el-button',
- { ref: 'trigger', attrs: { type: type, size: size },
- 'class': 'el-dropdown__caret-button' },
- [h(
- 'i',
- { 'class': 'el-dropdown__icon el-icon-caret-bottom' },
- []
- )]
- )]
- );
-
- return h(
- 'div',
- { 'class': 'el-dropdown', directives: [{
- name: 'clickoutside',
- value: hide
- }]
+ }
},
- [triggerElm, this.$slots.dropdown]
- );
- }
- };
-
-/***/ },
-/* 31 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(48);
-
-/***/ },
-/* 32 */
-/***/ function(module, exports) {
- module.exports = __webpack_require__(49);
+ render: function render(h) {
+ var _this = this;
-/***/ },
-/* 33 */
-/***/ function(module, exports, __webpack_require__) {
+ return h(
+ 'span',
+ { 'class': 'el-pagination__sizes' },
+ [h(
+ 'el-select',
+ {
+ attrs: {
+ value: this.$parent.internalPageSize
+ },
+ on: {
+ 'input': this.handleChange
+ }
+ },
+ [this.pageSizes.map(function (item) {
+ return h(
+ 'el-option',
+ {
+ attrs: {
+ value: item,
+ label: item + ' ' + _this.t('el.pagination.pagesize') }
+ },
+ []
+ );
+ })]
+ )]
+ );
+ },
- 'use strict';
- exports.__esModule = true;
+ components: {
+ ElSelect: _select2.default,
+ ElOption: _option2.default
+ },
- var _dropdownMenu = __webpack_require__(34);
+ methods: {
+ handleChange: function handleChange(val) {
+ if (val !== this.$parent.internalPageSize) {
+ this.$parent.internalPageSize = val = parseInt(val, 10);
+ this.$parent.$emit('size-change', val);
+ }
+ }
+ }
+ },
- var _dropdownMenu2 = _interopRequireDefault(_dropdownMenu);
+ Jumper: {
+ mixins: [_locale2.default],
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ data: function data() {
+ return {
+ oldValue: null
+ };
+ },
- /* istanbul ignore next */
- _dropdownMenu2.default.install = function (Vue) {
- Vue.component(_dropdownMenu2.default.name, _dropdownMenu2.default);
- };
- exports.default = _dropdownMenu2.default;
-
-/***/ },
-/* 34 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(35),
- /* template */
- __webpack_require__(36),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
+ methods: {
+ handleFocus: function handleFocus(event) {
+ this.oldValue = event.target.value;
+ },
+ handleBlur: function handleBlur(_ref) {
+ var target = _ref.target;
+ this.reassignMaxValue(target);
+ },
+ handleKeyUp: function handleKeyUp(event) {
+ var key = event.key || '';
+ var keyCode = event.keyCode || '';
+ if (key && key === 'Enter' || keyCode && keyCode === 13) {
+ this.reassignMaxValue(event.target);
+ this.handleChange({ target: event.target });
+ }
+ },
+ handleChange: function handleChange(_ref2) {
+ var target = _ref2.target;
-/***/ },
-/* 35 */
-/***/ function(module, exports, __webpack_require__) {
+ this.$parent.internalCurrentPage = this.$parent.getValidCurrentPage(target.value);
+ this.oldValue = null;
+ },
+ reassignMaxValue: function reassignMaxValue(target) {
+ if (+target.value > this.$parent.internalPageCount) {
+ target.value = this.$parent.internalPageCount;
+ }
+ }
+ },
- 'use strict';
+ render: function render(h) {
+ return h(
+ 'span',
+ { 'class': 'el-pagination__jump' },
+ [this.t('el.pagination.goto'), h(
+ 'input',
+ {
+ 'class': 'el-pagination__editor',
+ attrs: { type: 'number',
+ min: 1,
+ max: this.$parent.internalPageCount,
+ value: this.$parent.internalCurrentPage,
- exports.__esModule = true;
+ number: true },
+ domProps: {
+ 'value': this.$parent.internalCurrentPage
+ },
+ on: {
+ 'change': this.handleChange,
+ 'focus': this.handleFocus,
+ 'blur': this.handleBlur,
+ 'keyup': this.handleKeyUp
+ }
+ },
+ []
+ ), this.t('el.pagination.pageClassifier')]
+ );
+ }
+ },
- var _vuePopper = __webpack_require__(24);
+ Total: {
+ mixins: [_locale2.default],
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
+ 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 })]
+ ) : '';
+ }
+ },
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ Pager: _pager2.default
+ },
- exports.default = {
- name: 'ElDropdownMenu',
+ methods: {
+ handleCurrentChange: function handleCurrentChange(val) {
+ this.internalCurrentPage = this.getValidCurrentPage(val);
+ },
+ prev: function prev() {
+ var newVal = this.internalCurrentPage - 1;
+ this.internalCurrentPage = this.getValidCurrentPage(newVal);
+ },
+ next: function next() {
+ var newVal = this.internalCurrentPage + 1;
+ this.internalCurrentPage = this.getValidCurrentPage(newVal);
+ },
+ getValidCurrentPage: function getValidCurrentPage(value) {
+ value = parseInt(value, 10);
- componentName: 'ElDropdownMenu',
+ var havePageCount = typeof this.internalPageCount === 'number';
- mixins: [_vuePopper2.default],
+ 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;
+ }
+ }
- created: function created() {
- var _this = this;
+ if (resetValue === undefined && isNaN(value)) {
+ resetValue = 1;
+ } else if (resetValue === 0) {
+ resetValue = 1;
+ }
- this.$on('updatePopper', function () {
- if (_this.showPopper) _this.updatePopper();
- });
- this.$on('visible', function (val) {
- _this.showPopper = val;
- });
- },
- mounted: function mounted() {
- this.$parent.popperElm = this.popperElm = this.$el;
- this.referenceElm = this.$parent.$el;
+ return resetValue === undefined ? value : resetValue;
+ }
},
+ computed: {
+ internalPageCount: function internalPageCount() {
+ if (typeof this.total === 'number') {
+ return Math.ceil(this.total / this.internalPageSize);
+ } else if (typeof this.pageCount === 'number') {
+ return this.pageCount;
+ }
+ return null;
+ }
+ },
watch: {
- '$parent.menuAlign': {
+ currentPage: {
immediate: true,
handler: function handler(val) {
- this.currentPlacement = 'bottom-' + val;
+ this.internalCurrentPage = val;
}
- }
- }
- }; //
- //
- //
- //
- //
- //
- //
-
-/***/ },
-/* 36 */
-/***/ function(module, exports) {
-
- module.exports={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"
- }, [_vm._t("default")], 2)])
- },staticRenderFns: []}
-
-/***/ },
-/* 37 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
- exports.__esModule = true;
+ pageSize: {
+ immediate: true,
+ handler: function handler(val) {
+ this.internalPageSize = val;
+ }
+ },
- var _dropdownItem = __webpack_require__(38);
+ internalCurrentPage: function internalCurrentPage(newVal, oldVal) {
+ var _this2 = this;
- var _dropdownItem2 = _interopRequireDefault(_dropdownItem);
+ newVal = parseInt(newVal, 10);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ /* istanbul ignore if */
+ if (isNaN(newVal)) {
+ newVal = oldVal || 1;
+ } else {
+ newVal = this.getValidCurrentPage(newVal);
+ }
- /* istanbul ignore next */
- _dropdownItem2.default.install = function (Vue) {
- Vue.component(_dropdownItem2.default.name, _dropdownItem2.default);
+ if (newVal !== undefined) {
+ this.$nextTick(function () {
+ _this2.internalCurrentPage = newVal;
+ if (oldVal !== newVal) {
+ _this2.$emit('update:currentPage', newVal);
+ _this2.$emit('current-change', _this2.internalCurrentPage);
+ }
+ });
+ } else {
+ this.$emit('update:currentPage', newVal);
+ this.$emit('current-change', this.internalCurrentPage);
+ }
+ },
+ 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;
+ }
+ }
+ }
};
- exports.default = _dropdownItem2.default;
-
/***/ },
-/* 38 */
+/* 4 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(39),
+ __webpack_require__(6),
/* template */
- __webpack_require__(40),
+ __webpack_require__(7),
/* styles */
null,
/* scopeId */
@@ -36202,36 +36142,101 @@ module.exports =
/***/ },
-/* 39 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
+/* 5 */
+/***/ function(module, exports) {
- exports.__esModule = true;
+ /* globals __VUE_SSR_CONTEXT__ */
- var _emitter = __webpack_require__(15);
+ // this module is a runtime utility for cleaner component module output and will
+ // be included in the final webpack user bundle
- var _emitter2 = _interopRequireDefault(_emitter);
+ module.exports = function normalizeComponent (
+ rawScriptExports,
+ compiledTemplate,
+ injectStyles,
+ scopeId,
+ moduleIdentifier /* server only */
+ ) {
+ var esModule
+ var scriptExports = rawScriptExports = rawScriptExports || {}
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ // ES6 modules interop
+ var type = typeof rawScriptExports.default
+ if (type === 'object' || type === 'function') {
+ esModule = rawScriptExports
+ scriptExports = rawScriptExports.default
+ }
- exports.default = {
- name: 'ElDropdownItem',
+ // Vue.extend constructor export interop
+ var options = typeof scriptExports === 'function'
+ ? scriptExports.options
+ : scriptExports
- mixins: [_emitter2.default],
+ // render functions
+ if (compiledTemplate) {
+ options.render = compiledTemplate.render
+ options.staticRenderFns = compiledTemplate.staticRenderFns
+ }
- props: {
- command: {},
- disabled: Boolean,
- divided: Boolean
- },
+ // scopedId
+ if (scopeId) {
+ options._scopeId = scopeId
+ }
- methods: {
- handleClick: function handleClick(e) {
- this.dispatch('ElDropdown', 'menu-item-click', [this.command, this]);
+ var hook
+ if (moduleIdentifier) { // server build
+ hook = function (context) {
+ // 2.3 injection
+ context = context || (this.$vnode && this.$vnode.ssrContext)
+ // 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 = injectStyles
}
- }; //
+
+ if (hook) {
+ // inject component registration as beforeCreate hook
+ var existing = options.beforeCreate
+ options.beforeCreate = existing
+ ? [].concat(existing, hook)
+ : [hook]
+ }
+
+ return {
+ esModule: esModule,
+ exports: scriptExports,
+ options: options
+ }
+ }
+
+
+/***/ },
+/* 6 */
+/***/ function(module, exports) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+ //
//
//
//
@@ -36243,81 +36248,6 @@ module.exports =
//
//
//
-
-/***/ },
-/* 40 */
-/***/ function(module, exports) {
-
- module.exports={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
- },
- on: {
- "click": _vm.handleClick
- }
- }, [_vm._t("default")], 2)
- },staticRenderFns: []}
-
-/***/ },
-/* 41 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _menu = __webpack_require__(42);
-
- var _menu2 = _interopRequireDefault(_menu);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _menu2.default.install = function (Vue) {
- Vue.component(_menu2.default.name, _menu2.default);
- };
-
- exports.default = _menu2.default;
-
-/***/ },
-/* 42 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(43),
- /* template */
- __webpack_require__(45),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
-
-/***/ },
-/* 43 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _emitter = __webpack_require__(15);
-
- var _emitter2 = _interopRequireDefault(_emitter);
-
- var _dom = __webpack_require__(44);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
//
//
//
@@ -36334,266 +36264,219 @@ module.exports =
//
exports.default = {
- name: 'ElMenu',
-
- componentName: 'ElMenu',
+ name: 'ElPager',
- mixins: [_emitter2.default],
+ props: {
+ currentPage: Number,
- provide: function provide() {
- return {
- rootMenu: this
- };
+ pageCount: Number
},
+ watch: {
+ showPrevMore: function showPrevMore(val) {
+ if (!val) this.quickprevIconClass = 'el-icon-more';
+ },
+ showNextMore: function showNextMore(val) {
+ if (!val) this.quicknextIconClass = 'el-icon-more';
+ }
+ },
- 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) {
- (0, _dom.addClass)(el, 'el-opacity-transition');
- el.style.opacity = 1;
- },
- afterEnter: function afterEnter(el) {
- (0, _dom.removeClass)(el, 'el-opacity-transition');
- el.style.opacity = '';
- },
- beforeLeave: function beforeLeave(el) {
- if (!el.dataset) el.dataset = {};
+ methods: {
+ onPagerClick: function onPagerClick(event) {
+ var target = event.target;
+ if (target.tagName === 'UL') {
+ return;
+ }
- if ((0, _dom.hasClass)(el, 'el-menu--collapse')) {
- (0, _dom.removeClass)(el, 'el-menu--collapse');
- el.dataset.oldOverflow = el.style.overflow;
- el.dataset.scrollWidth = el.scrollWidth;
- (0, _dom.addClass)(el, 'el-menu--collapse');
- }
+ var newPage = Number(event.target.textContent);
+ var pageCount = this.pageCount;
+ var currentPage = this.currentPage;
- el.style.width = el.scrollWidth + 'px';
- el.style.overflow = 'hidden';
- },
- leave: function leave(el) {
- if (!(0, _dom.hasClass)(el, 'el-menu--collapse')) {
- (0, _dom.addClass)(el, 'horizontal-collapse-transition');
- el.style.width = '64px';
- } else {
- (0, _dom.addClass)(el, 'horizontal-collapse-transition');
- el.style.width = el.dataset.scrollWidth + 'px';
- }
- },
- afterLeave: function afterLeave(el) {
- (0, _dom.removeClass)(el, 'horizontal-collapse-transition');
- if ((0, _dom.hasClass)(el, 'el-menu--collapse')) {
- el.style.width = el.dataset.scrollWidth + 'px';
- } else {
- el.style.width = '64px';
- }
- el.style.overflow = el.dataset.oldOverflow;
- }
- }
- };
- return createElement('transition', data, context.children);
+ if (target.className.indexOf('more') !== -1) {
+ if (target.className.indexOf('quickprev') !== -1) {
+ newPage = currentPage - 5;
+ } else if (target.className.indexOf('quicknext') !== -1) {
+ newPage = currentPage + 5;
+ }
}
- }
- },
- props: {
- mode: {
- type: String,
- default: 'vertical'
- },
- defaultActive: {
- type: String,
- default: ''
- },
- defaultOpeneds: Array,
- theme: {
- type: String,
- default: 'light'
- },
- uniqueOpened: Boolean,
- router: Boolean,
- menuTrigger: {
- type: String,
- default: 'hover'
- },
- collapse: Boolean
- },
- data: function data() {
- return {
- activeIndex: this.defaultActive,
- openedMenus: this.defaultOpeneds ? this.defaultOpeneds.slice(0) : [],
- items: {},
- submenus: {}
- };
- },
+ /* istanbul ignore if */
+ if (!isNaN(newPage)) {
+ if (newPage < 1) {
+ newPage = 1;
+ }
- watch: {
- defaultActive: function defaultActive(value) {
- var item = this.items[value];
- if (item) {
- this.activeIndex = item.index;
- this.initOpenedMenu();
- } else {
- this.activeIndex = '';
+ if (newPage > pageCount) {
+ newPage = pageCount;
+ }
+ }
+
+ if (newPage !== currentPage) {
+ this.$emit('change', newPage);
}
- },
- defaultOpeneds: function defaultOpeneds(value) {
- this.openedMenus = value;
- },
- collapse: function collapse(value) {
- if (value) this.openedMenus = [];
}
},
- methods: {
- 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;
- // 将不在该菜单路径下的其余菜单收起
- if (this.uniqueOpened) {
- this.openedMenus = openedMenus.filter(function (index) {
- return indexPath.indexOf(index) !== -1;
- });
- }
- this.openedMenus.push(index);
- },
- closeMenu: function closeMenu(index) {
- this.openedMenus.splice(this.openedMenus.indexOf(index), 1);
- },
- handleSubmenuClick: function handleSubmenuClick(submenu) {
- var index = submenu.index,
- indexPath = submenu.indexPath;
- var isOpened = this.openedMenus.indexOf(index) !== -1;
+ computed: {
+ pagers: function pagers() {
+ var pagerCount = 7;
- 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 index = item.index,
- indexPath = item.indexPath;
+ var currentPage = Number(this.currentPage);
+ var pageCount = Number(this.pageCount);
- this.activeIndex = item.index;
- this.$emit('select', index, indexPath, item);
+ var showPrevMore = false;
+ var showNextMore = false;
- if (this.mode === 'horizontal' || this.collapse) {
- this.openedMenus = [];
- }
+ if (pageCount > pagerCount) {
+ if (currentPage > pagerCount - 3) {
+ showPrevMore = true;
+ }
- if (this.router) {
- this.routeToItem(item);
+ if (currentPage < pageCount - 3) {
+ showNextMore = true;
+ }
}
- },
- // 初始化展开菜单
- initOpenedMenu: function initOpenedMenu() {
- var _this = this;
+ var array = [];
- var index = this.activeIndex;
- var activeItem = this.items[index];
- if (!activeItem || this.mode === 'horizontal' || this.collapse) return;
+ 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);
+ }
+ }
- var indexPath = activeItem.indexPath;
+ this.showPrevMore = showPrevMore;
+ this.showNextMore = showNextMore;
- // 展开该菜单项的路径上所有子菜单
- indexPath.forEach(function (index) {
- var submenu = _this.submenus[index];
- submenu && _this.openMenu(index, submenu.indexPath);
- });
- },
- routeToItem: function routeToItem(item) {
- var route = item.route || item.index;
- try {
- this.$router.push(route);
- } catch (e) {
- console.error(e);
- }
+ return array;
}
},
- mounted: function mounted() {
- this.initOpenedMenu();
- this.$on('item-click', this.handleItemClick);
- this.$on('submenu-click', this.handleSubmenuClick);
+
+ data: function data() {
+ return {
+ current: null,
+ showPrevMore: false,
+ showNextMore: false,
+ quicknextIconClass: 'el-icon-more',
+ quickprevIconClass: 'el-icon-more'
+ };
}
};
/***/ },
-/* 44 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(4);
-
-/***/ },
-/* 45 */
+/* 7 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('el-menu-collapse-transition', [_c('ul', {
- key: +_vm.collapse,
- staticClass: "el-menu",
+ return _c('ul', {
+ staticClass: "el-pager",
+ on: {
+ "click": _vm.onPagerClick
+ }
+ }, [(_vm.pageCount > 0) ? _c('li', {
+ staticClass: "number",
class: {
- 'el-menu--horizontal': _vm.mode === 'horizontal',
- 'el-menu--dark': _vm.theme === 'dark',
- 'el-menu--collapse': _vm.collapse
+ active: _vm.currentPage === 1
}
- }, [_vm._t("default")], 2)])
+ }, [_vm._v("1")]) : _vm._e(), (_vm.showPrevMore) ? _c('li', {
+ staticClass: "el-icon more btn-quickprev",
+ class: [_vm.quickprevIconClass],
+ on: {
+ "mouseenter": function($event) {
+ _vm.quickprevIconClass = 'el-icon-d-arrow-left'
+ },
+ "mouseleave": function($event) {
+ _vm.quickprevIconClass = 'el-icon-more'
+ }
+ }
+ }) : _vm._e(), _vm._l((_vm.pagers), function(pager) {
+ return _c('li', {
+ staticClass: "number",
+ class: {
+ active: _vm.currentPage === pager
+ }
+ }, [_vm._v(_vm._s(pager))])
+ }), (_vm.showNextMore) ? _c('li', {
+ staticClass: "el-icon more btn-quicknext",
+ class: [_vm.quicknextIconClass],
+ on: {
+ "mouseenter": function($event) {
+ _vm.quicknextIconClass = 'el-icon-d-arrow-right'
+ },
+ "mouseleave": function($event) {
+ _vm.quicknextIconClass = 'el-icon-more'
+ }
+ }
+ }) : _vm._e(), (_vm.pageCount > 1) ? _c('li', {
+ staticClass: "number",
+ class: {
+ active: _vm.currentPage === _vm.pageCount
+ }
+ }, [_vm._v(_vm._s(_vm.pageCount))]) : _vm._e()], 2)
},staticRenderFns: []}
/***/ },
-/* 46 */
+/* 8 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(42);
+
+/***/ },
+/* 9 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(48);
+
+/***/ },
+/* 10 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(24);
+
+/***/ },
+/* 11 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _submenu = __webpack_require__(47);
+ var _component = __webpack_require__(12);
- var _submenu2 = _interopRequireDefault(_submenu);
+ var _component2 = _interopRequireDefault(_component);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _submenu2.default.install = function (Vue) {
- Vue.component(_submenu2.default.name, _submenu2.default);
+ _component2.default.install = function (Vue) {
+ Vue.component(_component2.default.name, _component2.default);
};
- exports.default = _submenu2.default;
+ exports.default = _component2.default;
/***/ },
-/* 47 */
+/* 12 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(48),
+ __webpack_require__(13),
/* template */
- __webpack_require__(51),
+ __webpack_require__(16),
/* styles */
null,
/* scopeId */
@@ -36606,20 +36489,16 @@ module.exports =
/***/ },
-/* 48 */
+/* 13 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _collapseTransition = __webpack_require__(49);
-
- var _collapseTransition2 = _interopRequireDefault(_collapseTransition);
-
- var _menuMixin = __webpack_require__(50);
+ var _popup = __webpack_require__(14);
- var _menuMixin2 = _interopRequireDefault(_menuMixin);
+ var _popup2 = _interopRequireDefault(_popup);
var _emitter = __webpack_require__(15);
@@ -36627,121 +36506,6 @@ module.exports =
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- exports.default = {
- name: 'ElSubmenu',
-
- componentName: 'ElSubmenu',
-
- mixins: [_menuMixin2.default, _emitter2.default],
-
- components: { ElCollapseTransition: _collapseTransition2.default },
-
- props: {
- index: {
- type: String,
- required: true
- }
- },
-
- data: function data() {
- return {
- timeout: null,
- items: {},
- submenus: {}
- };
- },
-
- computed: {
- 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: {
- cache: false,
- get: function get() {
- 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;
- }
- }
- },
- methods: {
- 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;
-
- if (rootMenu.menuTrigger === 'hover' && rootMenu.mode === 'horizontal' || rootMenu.collapse && rootMenu.mode === 'vertical') {
- return;
- }
- this.dispatch('ElMenu', 'submenu-click', this);
- },
- handleMouseenter: function handleMouseenter() {
- var _this = this;
-
- var rootMenu = this.rootMenu;
-
- if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical') {
- return;
- }
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this.rootMenu.openMenu(_this.index, _this.indexPath);
- }, 300);
- },
- handleMouseleave: function handleMouseleave() {
- var _this2 = this;
-
- var rootMenu = this.rootMenu;
-
- if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical') {
- return;
- }
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this2.rootMenu.closeMenu(_this2.index);
- }, 300);
- }
- },
- created: function created() {
- this.parentMenu.addSubmenu(this);
- this.rootMenu.addSubmenu(this);
- },
- beforeDestroy: function beforeDestroy() {
- this.parentMenu.removeSubmenu(this);
- this.rootMenu.removeSubmenu(this);
- }
- }; //
- //
- //
- //
//
//
//
@@ -36769,149 +36533,215 @@ module.exports =
//
//
-/***/ },
-/* 49 */
-/***/ function(module, exports) {
+ exports.default = {
+ name: 'ElDialog',
- module.exports = __webpack_require__(50);
+ mixins: [_popup2.default, _emitter2.default],
-/***/ },
-/* 50 */
-/***/ function(module, exports) {
+ props: {
+ title: {
+ type: String,
+ default: ''
+ },
- 'use strict';
+ modal: {
+ type: Boolean,
+ default: true
+ },
- exports.__esModule = true;
- exports.default = {
- 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;
+ modalAppendToBody: {
+ type: Boolean,
+ default: true
},
- rootMenu: function rootMenu() {
- var parent = this.$parent;
- while (parent && parent.$options.componentName !== 'ElMenu') {
- parent = parent.$parent;
- }
- return parent;
+
+ lockScroll: {
+ type: Boolean,
+ default: true
},
- parentMenu: function parentMenu() {
- var parent = this.$parent;
- while (parent && ['ElMenu', 'ElSubmenu'].indexOf(parent.$options.componentName) === -1) {
- parent = parent.$parent;
- }
- return parent;
+
+ closeOnClickModal: {
+ type: Boolean,
+ default: true
},
- paddingStyle: function paddingStyle() {
- if (this.rootMenu.mode !== 'vertical') return {};
- var padding = 20;
- var parent = this.$parent;
+ closeOnPressEscape: {
+ type: Boolean,
+ default: true
+ },
- if (this.rootMenu.collapse) {
- padding = 20;
+ showClose: {
+ type: Boolean,
+ default: true
+ },
+
+ size: {
+ type: String,
+ default: 'small'
+ },
+
+ customClass: {
+ type: String,
+ default: ''
+ },
+
+ top: {
+ type: String,
+ default: '15%'
+ },
+ beforeClose: Function
+ },
+
+ watch: {
+ visible: function visible(val) {
+ var _this = this;
+
+ this.$emit('update:visible', val);
+ if (val) {
+ this.$emit('open');
+ this.$el.addEventListener('scroll', this.updatePopper);
+ this.$nextTick(function () {
+ _this.$refs.dialog.scrollTop = 0;
+ });
} else {
- while (parent && parent.$options.componentName !== 'ElMenu') {
- if (parent.$options.componentName === 'ElSubmenu') {
- padding += 20;
- }
- parent = parent.$parent;
- }
+ this.$el.removeEventListener('scroll', this.updatePopper);
+ this.$emit('close');
}
- return { paddingLeft: padding + 'px' };
}
- }
- };
+ },
-/***/ },
-/* 51 */
-/***/ function(module, exports) {
+ computed: {
+ sizeClass: function sizeClass() {
+ return 'el-dialog--' + this.size;
+ },
+ style: function style() {
+ return this.size === 'full' ? {} : { 'top': this.top };
+ }
+ },
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('li', {
- class: {
- 'el-submenu': true,
- 'is-active': _vm.active,
- 'is-opened': _vm.opened
+ methods: {
+ handleWrapperClick: function handleWrapperClick() {
+ if (!this.closeOnClickModal) return;
+ this.handleClose();
},
- on: {
- "mouseenter": _vm.handleMouseenter,
- "mouseleave": _vm.handleMouseleave
- }
- }, [_c('div', {
- ref: "submenu-title",
- staticClass: "el-submenu__title",
- style: (_vm.paddingStyle),
- on: {
- "click": _vm.handleClick
+ 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('visible-change', false);
+ }
+ },
+ updatePopper: function updatePopper() {
+ this.broadcast('ElSelectDropdown', 'updatePopper');
+ this.broadcast('ElDropdownMenu', 'updatePopper');
}
- }, [_vm._t("title"), _c('i', {
- class: {
- 'el-submenu__icon-arrow': true,
- 'el-icon-caret-bottom': _vm.rootMenu.mode === 'horizontal',
- 'el-icon-arrow-down': _vm.rootMenu.mode === 'vertical' && !_vm.rootMenu.collapse,
- 'el-icon-caret-right': _vm.rootMenu.mode === 'vertical' && _vm.rootMenu.collapse
+ },
+
+ mounted: function mounted() {
+ if (this.visible) {
+ this.rendered = true;
+ this.open();
}
- })], 2), (_vm.rootMenu.mode === 'horizontal' || (_vm.rootMenu.mode === 'vertical' && _vm.rootMenu.collapse)) ? [_c('transition', {
+ }
+ };
+
+/***/ },
+/* 14 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(21);
+
+/***/ },
+/* 15 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(5);
+
+/***/ },
+/* 16 */
+/***/ function(module, exports) {
+
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('transition', {
attrs: {
- "name": _vm.menuTransitionName
+ "name": "dialog-fade"
}
- }, [_c('ul', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.opened),
- expression: "opened"
- }],
- staticClass: "el-menu"
- }, [_vm._t("default")], 2)])] : _c('el-collapse-transition', [_c('ul', {
+ }, [_c('div', {
directives: [{
name: "show",
rawName: "v-show",
- value: (_vm.opened),
- expression: "opened"
+ value: (_vm.visible),
+ expression: "visible"
}],
- staticClass: "el-menu"
- }, [_vm._t("default")], 2)])], 2)
+ staticClass: "el-dialog__wrapper",
+ on: {
+ "click": function($event) {
+ if ($event.target !== $event.currentTarget) { return null; }
+ _vm.handleWrapperClick($event)
+ }
+ }
+ }, [_c('div', {
+ ref: "dialog",
+ staticClass: "el-dialog",
+ class: [_vm.sizeClass, _vm.customClass],
+ style: (_vm.style)
+ }, [_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()])])])
},staticRenderFns: []}
/***/ },
-/* 52 */
+/* 17 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _menuItem = __webpack_require__(53);
+ var _autocomplete = __webpack_require__(18);
- var _menuItem2 = _interopRequireDefault(_menuItem);
+ var _autocomplete2 = _interopRequireDefault(_autocomplete);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _menuItem2.default.install = function (Vue) {
- Vue.component(_menuItem2.default.name, _menuItem2.default);
+ _autocomplete2.default.install = function (Vue) {
+ Vue.component(_autocomplete2.default.name, _autocomplete2.default);
};
- exports.default = _menuItem2.default;
+ exports.default = _autocomplete2.default;
/***/ },
-/* 53 */
+/* 18 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(54),
+ __webpack_require__(19),
/* template */
- __webpack_require__(55),
+ __webpack_require__(27),
/* styles */
null,
/* scopeId */
@@ -36924,16 +36754,24 @@ module.exports =
/***/ },
-/* 54 */
+/* 19 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _menuMixin = __webpack_require__(50);
+ var _input = __webpack_require__(20);
- var _menuMixin2 = _interopRequireDefault(_menuMixin);
+ var _input2 = _interopRequireDefault(_input);
+
+ var _clickoutside = __webpack_require__(21);
+
+ var _clickoutside2 = _interopRequireDefault(_clickoutside);
+
+ var _autocompleteSuggestions = __webpack_require__(22);
+
+ var _autocompleteSuggestions2 = _interopRequireDefault(_autocompleteSuggestions);
var _emitter = __webpack_require__(15);
@@ -36964,224 +36802,189 @@ module.exports =
//
//
//
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
exports.default = {
- name: 'ElMenuItem',
+ name: 'ElAutocomplete',
- componentName: 'ElMenuItem',
+ mixins: [_emitter2.default],
- mixins: [_menuMixin2.default, _emitter2.default],
+ componentName: 'ElAutocomplete',
+
+ components: {
+ ElInput: _input2.default,
+ ElAutocompleteSuggestions: _autocompleteSuggestions2.default
+ },
+
+ directives: { Clickoutside: _clickoutside2.default },
props: {
- index: {
- type: String,
- required: true
- },
- route: {
+ props: {
type: Object,
- required: false
+ default: function _default() {
+ return {
+ label: 'value',
+ value: 'value'
+ };
+ }
},
- disabled: {
+ popperClass: String,
+ placeholder: String,
+ disabled: Boolean,
+ name: String,
+ size: String,
+ value: String,
+ autofocus: Boolean,
+ fetchSuggestions: Function,
+ triggerOnFocus: {
type: Boolean,
- required: false
- }
+ default: true
+ },
+ customItem: String,
+ icon: String,
+ onIconClick: Function
+ },
+ data: function data() {
+ return {
+ activated: false,
+ isOnComposition: false,
+ suggestions: [],
+ loading: false,
+ highlightedIndex: -1
+ };
},
+
computed: {
- active: function active() {
- return this.index === this.rootMenu.activeIndex;
+ suggestionVisible: function suggestionVisible() {
+ var suggestions = this.suggestions;
+ var isValidData = Array.isArray(suggestions) && suggestions.length > 0;
+ return (isValidData || this.loading) && this.activated;
}
},
- methods: {
- handleClick: function handleClick() {
- this.dispatch('ElMenu', 'item-click', this);
- this.$emit('click', this);
+ watch: {
+ suggestionVisible: function suggestionVisible(val) {
+ this.broadcast('ElAutocompleteSuggestions', 'visible', [val, this.$refs.input.$refs.input.offsetWidth]);
}
},
- created: function created() {
- this.parentMenu.addItem(this);
- this.rootMenu.addItem(this);
- },
- beforeDestroy: function beforeDestroy() {
- this.parentMenu.removeItem(this);
- this.rootMenu.removeItem(this);
- }
- };
-
-/***/ },
-/* 55 */
-/***/ function(module, exports) {
+ methods: {
+ getData: function getData(queryString) {
+ var _this = this;
- module.exports={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
+ this.loading = true;
+ this.fetchSuggestions(queryString, function (suggestions) {
+ _this.loading = false;
+ if (Array.isArray(suggestions)) {
+ _this.suggestions = suggestions;
+ } else {
+ console.error('autocomplete suggestions must be an array');
+ }
+ });
},
- style: (_vm.paddingStyle),
- on: {
- "click": _vm.handleClick
- }
- }, [(_vm.$parent === _vm.rootMenu && _vm.rootMenu.collapse) ? _c('el-tooltip', {
- attrs: {
- "effect": "dark",
- "placement": "right"
- }
- }, [_c('div', {
- 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)
- },staticRenderFns: []}
-
-/***/ },
-/* 56 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _menuItemGroup = __webpack_require__(57);
-
- var _menuItemGroup2 = _interopRequireDefault(_menuItemGroup);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _menuItemGroup2.default.install = function (Vue) {
- Vue.component(_menuItemGroup2.default.name, _menuItemGroup2.default);
- };
-
- exports.default = _menuItemGroup2.default;
-
-/***/ },
-/* 57 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(58),
- /* template */
- __webpack_require__(59),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
-
-/***/ },
-/* 58 */
-/***/ function(module, exports) {
-
- 'use strict';
+ handleComposition: function handleComposition(event) {
+ if (event.type === 'compositionend') {
+ this.isOnComposition = false;
+ this.handleChange(this.value);
+ } else {
+ this.isOnComposition = true;
+ }
+ },
+ handleChange: function handleChange(value) {
+ this.$emit('input', value);
+ if (this.isOnComposition || !this.triggerOnFocus && !value) {
+ this.suggestions = [];
+ return;
+ }
+ this.getData(value);
+ },
+ handleFocus: function handleFocus() {
+ this.activated = true;
+ if (this.triggerOnFocus) {
+ this.getData(this.value);
+ }
+ },
+ close: function close(e) {
+ this.activated = false;
+ },
+ handleKeyEnter: function handleKeyEnter(e) {
+ if (this.suggestionVisible && this.highlightedIndex >= 0 && this.highlightedIndex < this.suggestions.length) {
+ e.preventDefault();
+ this.select(this.suggestions[this.highlightedIndex]);
+ }
+ },
+ select: function select(item) {
+ var _this2 = this;
- exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ this.$emit('input', item[this.props.value]);
+ this.$emit('select', item);
+ this.$nextTick(function (_) {
+ _this2.suggestions = [];
+ });
+ },
+ highlight: function highlight(index) {
+ if (!this.suggestionVisible || this.loading) {
+ return;
+ }
+ if (index < 0) index = 0;
+ 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');
- exports.default = {
- name: 'ElMenuItemGroup',
+ var highlightItem = suggestionList[index];
+ var scrollTop = suggestion.scrollTop;
+ var offsetTop = highlightItem.offsetTop;
- componentName: 'ElMenuItemGroup',
+ if (offsetTop + highlightItem.scrollHeight > scrollTop + suggestion.clientHeight) {
+ suggestion.scrollTop += highlightItem.scrollHeight;
+ }
+ if (offsetTop < scrollTop) {
+ suggestion.scrollTop -= highlightItem.scrollHeight;
+ }
- inject: ['rootMenu'],
- props: {
- title: {
- type: String
+ this.highlightedIndex = index;
}
},
- data: function data() {
- return {
- paddingLeft: 20
- };
- },
+ mounted: function mounted() {
+ var _this3 = this;
- computed: {
- levelPadding: function levelPadding() {
- var padding = 10;
- 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;
- }
- padding === 10 && (padding = 20);
- return padding;
- }
+ this.$on('item-click', function (item) {
+ _this3.select(item);
+ });
+ },
+ beforeDestroy: function beforeDestroy() {
+ this.$refs.suggestions.$destroy();
}
};
/***/ },
-/* 59 */
+/* 20 */
/***/ function(module, exports) {
- module.exports={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)])
- },staticRenderFns: []}
+ module.exports = __webpack_require__(11);
/***/ },
-/* 60 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _input = __webpack_require__(61);
-
- var _input2 = _interopRequireDefault(_input);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _input2.default.install = function (Vue) {
- Vue.component(_input2.default.name, _input2.default);
- };
+/* 21 */
+/***/ function(module, exports) {
- exports.default = _input2.default;
+ module.exports = __webpack_require__(20);
/***/ },
-/* 61 */
+/* 22 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(62),
+ __webpack_require__(23),
/* template */
- __webpack_require__(65),
+ __webpack_require__(26),
/* styles */
null,
/* scopeId */
@@ -37194,151 +36997,78 @@ module.exports =
/***/ },
-/* 62 */
+/* 23 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _emitter = __webpack_require__(15);
+ var _vuePopper = __webpack_require__(24);
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
- var _calcTextareaHeight = __webpack_require__(63);
+ var _emitter = __webpack_require__(15);
- var _calcTextareaHeight2 = _interopRequireDefault(_calcTextareaHeight);
+ var _emitter2 = _interopRequireDefault(_emitter);
- var _merge = __webpack_require__(64);
+ var _scrollbar = __webpack_require__(25);
- var _merge2 = _interopRequireDefault(_merge);
+ var _scrollbar2 = _interopRequireDefault(_scrollbar);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElInput',
-
- componentName: 'ElInput',
+ components: { ElScrollbar: _scrollbar2.default },
+ mixins: [_vuePopper2.default, _emitter2.default],
- mixins: [_emitter2.default],
+ componentName: 'ElAutocompleteSuggestions',
data: function data() {
return {
- currentValue: this.value,
- textareaCalcStyle: {}
+ parent: this.$parent,
+ dropdownWidth: ''
};
},
props: {
- value: [String, Number],
- placeholder: String,
- size: String,
- resize: String,
- readonly: Boolean,
- autofocus: Boolean,
- icon: String,
- disabled: Boolean,
- type: {
- type: String,
- default: 'text'
- },
- name: String,
- autosize: {
- type: [Boolean, Object],
- default: false
- },
- rows: {
- type: Number,
- default: 2
- },
- autoComplete: {
- type: String,
- default: 'off'
- },
- form: String,
- maxlength: Number,
- minlength: Number,
- max: {},
- min: {},
- step: {},
- validateEvent: {
- type: Boolean,
- default: true
- },
- onIconClick: Function
- },
-
- computed: {
- validating: function validating() {
- return this.$parent.validateState === 'validating';
- },
- textareaStyle: function textareaStyle() {
- return (0, _merge2.default)({}, this.textareaCalcStyle, { resize: this.resize });
- }
- },
-
- watch: {
- 'value': function value(val, oldValue) {
- this.setCurrentValue(val);
+ props: Object,
+ suggestions: Array,
+ options: {
+ default: function _default() {
+ return {
+ forceAbsolute: true,
+ gpuAcceleration: false
+ };
+ }
}
},
methods: {
- handleBlur: function handleBlur(event) {
- this.$emit('blur', event);
- if (this.validateEvent) {
- this.dispatch('ElFormItem', 'el.form.blur', [this.currentValue]);
- }
- },
- inputSelect: function inputSelect() {
- this.$refs.input.select();
- },
- resizeTextarea: function resizeTextarea() {
- if (this.$isServer) return;
- var autosize = this.autosize,
- type = this.type;
-
- if (!autosize || type !== 'textarea') return;
- var minRows = autosize.minRows;
- var maxRows = autosize.maxRows;
-
- this.textareaCalcStyle = (0, _calcTextareaHeight2.default)(this.$refs.textarea, minRows, maxRows);
- },
- handleFocus: function handleFocus(event) {
- this.$emit('focus', event);
- },
- handleInput: function handleInput(event) {
- var value = event.target.value;
- this.$emit('input', value);
- this.setCurrentValue(value);
- this.$emit('change', value);
- },
- handleIconClick: function handleIconClick(event) {
- if (this.onIconClick) {
- this.onIconClick(event);
- }
- this.$emit('click', event);
- },
- setCurrentValue: function setCurrentValue(value) {
- var _this = this;
-
- if (value === this.currentValue) return;
- this.$nextTick(function (_) {
- _this.resizeTextarea();
- });
- this.currentValue = value;
- if (this.validateEvent) {
- this.dispatch('ElFormItem', 'el.form.change', [value]);
- }
+ select: function select(item) {
+ this.dispatch('ElAutocomplete', 'item-click', item);
}
},
- created: function created() {
- this.$on('inputSelect', this.inputSelect);
+ updated: function updated() {
+ var _this = this;
+
+ this.$nextTick(function (_) {
+ _this.updatePopper();
+ });
},
mounted: function mounted() {
- this.resizeTextarea();
+ this.$parent.popperElm = this.popperElm = this.$el;
+ this.referenceElm = this.$parent.$refs.input.$refs.input;
+ },
+ created: function created() {
+ var _this2 = this;
+
+ this.$on('visible', function (val, inputWidth) {
+ _this2.dropdownWidth = inputWidth + 'px';
+ _this2.showPopper = val;
+ });
}
}; //
//
@@ -37375,201 +37105,170 @@ module.exports =
//
//
//
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
/***/ },
-/* 63 */
+/* 24 */
/***/ function(module, exports) {
- 'use strict';
-
- exports.__esModule = true;
- exports.default = calcTextareaHeight;
- 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] : null;
- 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;
-
- 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);
- }
- if (maxRows !== null) {
- var maxHeight = singleRowHeight * maxRows;
- if (boxSizing === 'border-box') {
- maxHeight = maxHeight + paddingSize + borderSize;
- }
- height = Math.min(maxHeight, height);
- }
-
- return { height: height + 'px' };
- };
+ module.exports = __webpack_require__(13);
/***/ },
-/* 64 */
+/* 25 */
/***/ function(module, exports) {
- module.exports = __webpack_require__(12);
+ module.exports = __webpack_require__(22);
/***/ },
-/* 65 */
+/* 26 */
/***/ function(module, exports) {
module.exports={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.size ? 'el-input--' + _vm.size : '', {
- 'is-disabled': _vm.disabled,
- 'el-input-group': _vm.$slots.prepend || _vm.$slots.append,
- 'el-input-group--append': _vm.$slots.append,
- 'el-input-group--prepend': _vm.$slots.prepend
- }
- ]
- }, [(_vm.type !== 'textarea') ? [(_vm.$slots.prepend) ? _c('div', {
- staticClass: "el-input-group__prepend"
- }, [_vm._t("prepend")], 2) : _vm._e(), _vm._t("icon", [(_vm.icon) ? _c('i', {
- staticClass: "el-input__icon",
- class: [
- 'el-icon-' + _vm.icon,
- _vm.onIconClick ? 'is-clickable' : ''
- ],
- on: {
- "click": _vm.handleIconClick
- }
- }) : _vm._e()]), (_vm.type !== 'textarea') ? _c('input', _vm._b({
- ref: "input",
- staticClass: "el-input__inner",
+ return _c('transition', {
attrs: {
- "autocomplete": _vm.autoComplete
- },
- domProps: {
- "value": _vm.currentValue
+ "name": "el-zoom-in-top"
},
on: {
- "input": _vm.handleInput,
- "focus": _vm.handleFocus,
- "blur": _vm.handleBlur
+ "after-leave": _vm.doDestroy
}
- }, 'input', _vm.$props)) : _vm._e(), (_vm.validating) ? _c('i', {
- staticClass: "el-input__icon el-icon-loading"
- }) : _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),
- domProps: {
- "value": _vm.currentValue
+ }, [_c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.showPopper),
+ expression: "showPopper"
+ }],
+ staticClass: "el-autocomplete-suggestion",
+ class: {
+ 'is-loading': _vm.parent.loading
},
+ style: ({
+ width: _vm.dropdownWidth
+ })
+ }, [_c('el-scrollbar', {
+ attrs: {
+ "tag": "ul",
+ "wrap-class": "el-autocomplete-suggestion__wrap",
+ "view-class": "el-autocomplete-suggestion__list"
+ }
+ }, [(_vm.parent.loading) ? _c('li', [_c('i', {
+ staticClass: "el-icon-loading"
+ })]) : _vm._l((_vm.suggestions), function(item, index) {
+ return [(!_vm.parent.customItem) ? _c('li', {
+ class: {
+ 'highlighted': _vm.parent.highlightedIndex === index
+ },
+ on: {
+ "click": function($event) {
+ _vm.select(item)
+ }
+ }
+ }, [_vm._v("\n " + _vm._s(item[_vm.props.label]) + "\n ")]) : _c(_vm.parent.customItem, {
+ tag: "component",
+ class: {
+ 'highlighted': _vm.parent.highlightedIndex === index
+ },
+ attrs: {
+ "item": item,
+ "index": index
+ },
+ on: {
+ "click": function($event) {
+ _vm.select(item)
+ }
+ }
+ })]
+ })], 2)], 1)])
+ },staticRenderFns: []}
+
+/***/ },
+/* 27 */
+/***/ function(module, exports) {
+
+ module.exports={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"
+ }, [_c('el-input', _vm._b({
+ ref: "input",
on: {
- "input": _vm.handleInput,
- "focus": _vm.handleFocus,
- "blur": _vm.handleBlur
+ "change": _vm.handleChange,
+ "focus": _vm.handleFocus
+ },
+ nativeOn: {
+ "compositionstart": function($event) {
+ _vm.handleComposition($event)
+ },
+ "compositionupdate": function($event) {
+ _vm.handleComposition($event)
+ },
+ "compositionend": function($event) {
+ _vm.handleComposition($event)
+ },
+ "keydown": [function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
+ $event.preventDefault();
+ _vm.highlight(_vm.highlightedIndex - 1)
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
+ $event.preventDefault();
+ _vm.highlight(_vm.highlightedIndex + 1)
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
+ _vm.handleKeyEnter($event)
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "tab", 9)) { return null; }
+ _vm.close($event)
+ }]
}
- }, 'textarea', _vm.$props))], 2)
+ }, 'el-input', _vm.$props), [(_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()], 2), _c('el-autocomplete-suggestions', {
+ ref: "suggestions",
+ class: [_vm.popperClass ? _vm.popperClass : ''],
+ attrs: {
+ "props": _vm.props,
+ "suggestions": _vm.suggestions
+ }
+ })], 1)
},staticRenderFns: []}
/***/ },
-/* 66 */
+/* 28 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _inputNumber = __webpack_require__(67);
+ var _dropdown = __webpack_require__(29);
- var _inputNumber2 = _interopRequireDefault(_inputNumber);
+ var _dropdown2 = _interopRequireDefault(_dropdown);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _inputNumber2.default.install = function (Vue) {
- Vue.component(_inputNumber2.default.name, _inputNumber2.default);
+ _dropdown2.default.install = function (Vue) {
+ Vue.component(_dropdown2.default.name, _dropdown2.default);
};
- exports.default = _inputNumber2.default;
+ exports.default = _dropdown2.default;
/***/ },
-/* 67 */
+/* 29 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(68),
+ __webpack_require__(30),
/* template */
- __webpack_require__(70),
+ null,
/* styles */
null,
/* scopeId */
@@ -37582,345 +37281,223 @@ module.exports =
/***/ },
-/* 68 */
+/* 30 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _input = __webpack_require__(20);
+ var _clickoutside = __webpack_require__(21);
- var _input2 = _interopRequireDefault(_input);
+ var _clickoutside2 = _interopRequireDefault(_clickoutside);
- var _dom = __webpack_require__(44);
+ var _emitter = __webpack_require__(15);
- var _debounce = __webpack_require__(69);
+ var _emitter2 = _interopRequireDefault(_emitter);
- var _debounce2 = _interopRequireDefault(_debounce);
+ var _button = __webpack_require__(31);
+
+ var _button2 = _interopRequireDefault(_button);
+
+ var _buttonGroup = __webpack_require__(32);
+
+ var _buttonGroup2 = _interopRequireDefault(_buttonGroup);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElInputNumber',
- directives: {
- repeatClick: {
- 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 (new Date() - startTime < 100) {
- handler();
- }
- clearInterval(interval);
- interval = null;
- };
+ name: 'ElDropdown',
+
+ componentName: 'ElDropdown',
+
+ mixins: [_emitter2.default],
+
+ directives: { Clickoutside: _clickoutside2.default },
- (0, _dom.on)(el, 'mousedown', function () {
- startTime = new Date();
- (0, _dom.once)(document, 'mouseup', clear);
- clearInterval(interval);
- interval = setInterval(handler, 100);
- });
- }
- }
- },
components: {
- ElInput: _input2.default
+ ElButton: _button2.default,
+ ElButtonGroup: _buttonGroup2.default
},
+
props: {
- step: {
- type: Number,
- default: 1
- },
- max: {
- type: Number,
- default: Infinity
- },
- min: {
- type: Number,
- default: -Infinity
+ trigger: {
+ type: String,
+ default: 'hover'
},
- value: {
- default: 0
+ menuAlign: {
+ type: String,
+ default: 'end'
},
- disabled: Boolean,
+ type: String,
size: String,
- controls: {
+ splitButton: Boolean,
+ hideOnClick: {
type: Boolean,
default: true
- },
- debounce: {
- type: Number,
- default: 300
}
},
+
data: function data() {
return {
- currentValue: 0
+ timeout: null,
+ visible: false
};
},
+ mounted: function mounted() {
+ this.$on('menu-item-click', this.handleMenuItemClick);
+ this.initEvent();
+ },
+
watch: {
- value: {
- immediate: true,
- handler: function handler(value) {
- var newVal = Number(value);
- if (isNaN(newVal)) return;
- if (newVal >= this.max) newVal = this.max;
- if (newVal <= this.min) newVal = this.min;
- this.currentValue = newVal;
- this.$emit('input', newVal);
- }
+ visible: function visible(val) {
+ this.broadcast('ElDropdownMenu', 'visible', val);
+ this.$emit('visible-change', val);
}
},
- 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;
- },
- precision: function precision() {
- var value = this.value,
- step = this.step,
- getPrecision = this.getPrecision;
- return Math.max(getPrecision(value), getPrecision(step));
- }
- },
methods: {
- toPrecision: function toPrecision(num, precision) {
- if (precision === undefined) precision = this.precision;
- return parseFloat(parseFloat(Number(num).toFixed(precision)));
+ show: function show() {
+ var _this = this;
+
+ clearTimeout(this.timeout);
+ this.timeout = setTimeout(function () {
+ _this.visible = true;
+ }, 250);
},
- getPrecision: function getPrecision(value) {
- var valueString = value.toString();
- var dotPosition = valueString.indexOf('.');
- var precision = 0;
- if (dotPosition !== -1) {
- precision = valueString.length - dotPosition - 1;
- }
- return precision;
+ hide: function hide() {
+ var _this2 = this;
+
+ clearTimeout(this.timeout);
+ this.timeout = setTimeout(function () {
+ _this2.visible = false;
+ }, 150);
},
- _increase: function _increase(val, step) {
- if (typeof val !== 'number') return this.currentValue;
+ handleClick: function handleClick() {
+ this.visible = !this.visible;
+ },
+ initEvent: function initEvent() {
+ var trigger = this.trigger,
+ show = this.show,
+ hide = this.hide,
+ handleClick = this.handleClick,
+ splitButton = this.splitButton;
- var precisionFactor = Math.pow(10, this.precision);
+ var triggerElm = splitButton ? this.$refs.trigger.$el : this.$slots.default[0].elm;
- return this.toPrecision((precisionFactor * val + precisionFactor * step) / precisionFactor);
- },
- _decrease: function _decrease(val, step) {
- if (typeof val !== 'number') return this.currentValue;
+ if (triggerElm.disabled) return;
+ if (trigger === 'hover') {
+ triggerElm.addEventListener('mouseenter', show);
+ triggerElm.addEventListener('mouseleave', hide);
- var precisionFactor = Math.pow(10, this.precision);
+ var dropdownElm = this.$slots.dropdown[0].elm;
- return this.toPrecision((precisionFactor * val - precisionFactor * step) / precisionFactor);
- },
- increase: function increase() {
- if (this.disabled || this.maxDisabled) return;
- var value = this.value || 0;
- var newVal = this._increase(value, this.step);
- if (newVal > this.max) return;
- this.setCurrentValue(newVal);
- },
- decrease: function decrease() {
- if (this.disabled || this.minDisabled) return;
- var value = this.value || 0;
- var newVal = this._decrease(value, this.step);
- if (newVal < this.min) return;
- this.setCurrentValue(newVal);
- },
- handleBlur: function handleBlur() {
- this.$refs.input.setCurrentValue(this.currentValue);
- },
- setCurrentValue: function setCurrentValue(newVal) {
- var oldVal = this.currentValue;
- if (newVal >= this.max) newVal = this.max;
- if (newVal <= this.min) newVal = this.min;
- if (oldVal === newVal) {
- this.$refs.input.setCurrentValue(this.currentValue);
- return;
+ dropdownElm.addEventListener('mouseenter', show);
+ dropdownElm.addEventListener('mouseleave', hide);
+ } else if (trigger === 'click') {
+ triggerElm.addEventListener('click', handleClick);
}
- this.$emit('change', newVal, oldVal);
- this.$emit('input', newVal);
- this.currentValue = newVal;
},
- handleInput: function handleInput(value) {
- if (value === '') {
- return;
- }
- var newVal = Number(value);
- if (!isNaN(newVal)) {
- this.setCurrentValue(newVal);
- } else {
- this.$refs.input.setCurrentValue(this.currentValue);
+ handleMenuItemClick: function handleMenuItemClick(command, instance) {
+ if (this.hideOnClick) {
+ this.visible = false;
}
+ this.$emit('command', command, instance);
}
},
- created: function created() {
- var _this = this;
- this.debounceHandleInput = (0, _debounce2.default)(this.debounce, function (value) {
- _this.handleInput(value);
- });
+ render: function render(h) {
+ var _this3 = this;
+
+ var hide = this.hide,
+ splitButton = this.splitButton,
+ type = this.type,
+ size = this.size;
+
+
+ var handleClick = function handleClick(_) {
+ _this3.$emit('click');
+ };
+
+ var triggerElm = !splitButton ? this.$slots.default : h(
+ 'el-button-group',
+ null,
+ [h(
+ 'el-button',
+ {
+ attrs: { type: type, size: size },
+ nativeOn: {
+ 'click': handleClick
+ }
+ },
+ [this.$slots.default]
+ ), h(
+ 'el-button',
+ { ref: 'trigger', attrs: { type: type, size: size },
+ 'class': 'el-dropdown__caret-button' },
+ [h(
+ 'i',
+ { 'class': 'el-dropdown__icon el-icon-caret-bottom' },
+ []
+ )]
+ )]
+ );
+
+ return h(
+ 'div',
+ { 'class': 'el-dropdown', directives: [{
+ name: 'clickoutside',
+ value: hide
+ }]
+ },
+ [triggerElm, this.$slots.dropdown]
+ );
}
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ };
/***/ },
-/* 69 */
+/* 31 */
/***/ function(module, exports) {
- module.exports = __webpack_require__(9);
+ module.exports = __webpack_require__(49);
/***/ },
-/* 70 */
+/* 32 */
/***/ function(module, exports) {
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-input-number",
- class: [
- _vm.size ? 'el-input-number--' + _vm.size : '', {
- 'is-disabled': _vm.disabled
- }, {
- 'is-without-controls': !_vm.controls
- }
- ]
- }, [(_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
- }
- }, [_c('i', {
- staticClass: "el-icon-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
- }
- }, [_c('i', {
- staticClass: "el-icon-plus"
- })]) : _vm._e(), _c('el-input', {
- ref: "input",
- attrs: {
- "value": _vm.currentValue,
- "disabled": _vm.disabled,
- "size": _vm.size,
- "max": _vm.max,
- "min": _vm.min
- },
- on: {
- "blur": _vm.handleBlur,
- "input": _vm.debounceHandleInput
- },
- nativeOn: {
- "keydown": [function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
- $event.preventDefault();
- _vm.increase($event)
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
- $event.preventDefault();
- _vm.decrease($event)
- }]
- }
- }, [(_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()], 2)], 1)
- },staticRenderFns: []}
+ module.exports = __webpack_require__(50);
/***/ },
-/* 71 */
+/* 33 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _radio = __webpack_require__(72);
+ var _dropdownMenu = __webpack_require__(34);
- var _radio2 = _interopRequireDefault(_radio);
+ var _dropdownMenu2 = _interopRequireDefault(_dropdownMenu);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _radio2.default.install = function (Vue) {
- Vue.component('el-radio', _radio2.default);
+ _dropdownMenu2.default.install = function (Vue) {
+ Vue.component(_dropdownMenu2.default.name, _dropdownMenu2.default);
};
- exports.default = _radio2.default;
+ exports.default = _dropdownMenu2.default;
/***/ },
-/* 72 */
+/* 34 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(73),
+ __webpack_require__(35),
/* template */
- __webpack_require__(74),
+ __webpack_require__(36),
/* styles */
null,
/* scopeId */
@@ -37933,70 +37510,48 @@ module.exports =
/***/ },
-/* 73 */
+/* 35 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _emitter = __webpack_require__(15);
+ var _vuePopper = __webpack_require__(24);
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElRadio',
+ name: 'ElDropdownMenu',
- mixins: [_emitter2.default],
+ componentName: 'ElDropdownMenu',
- componentName: 'ElRadio',
+ mixins: [_vuePopper2.default],
- props: {
- value: {},
- label: {},
- disabled: Boolean,
- name: String
- },
+ created: function created() {
+ var _this = this;
- data: function data() {
- return {
- focus: false
- };
+ this.$on('updatePopper', function () {
+ if (_this.showPopper) _this.updatePopper();
+ });
+ this.$on('visible', function (val) {
+ _this.showPopper = val;
+ });
+ },
+ mounted: function mounted() {
+ this.$parent.popperElm = this.popperElm = this.$el;
+ this.referenceElm = this.$parent.$el;
},
- 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);
- }
+ watch: {
+ '$parent.menuAlign': {
+ immediate: true,
+ handler: function handler(val) {
+ this.currentPlacement = 'bottom-' + val;
}
- },
-
- isDisabled: function isDisabled() {
- return this.isGroup ? this._radioGroup.disabled || this.disabled : this.disabled;
}
}
}; //
@@ -38006,105 +37561,60 @@ module.exports =
//
//
//
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
/***/ },
-/* 74 */
+/* 36 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('label', {
- staticClass: "el-radio"
- }, [_c('span', {
- staticClass: "el-radio__input",
- class: {
- 'is-disabled': _vm.isDisabled,
- 'is-checked': _vm.model === _vm.label,
- 'is-focus': _vm.focus
- }
- }, [_c('span', {
- staticClass: "el-radio__inner"
- }), _c('input', {
- directives: [{
- name: "model",
- rawName: "v-model",
- value: (_vm.model),
- expression: "model"
- }],
- staticClass: "el-radio__original",
+ return _c('transition', {
attrs: {
- "type": "radio",
- "name": _vm.name,
- "disabled": _vm.isDisabled
- },
- domProps: {
- "value": _vm.label,
- "checked": _vm._q(_vm.model, _vm.label)
+ "name": "el-zoom-in-top"
},
on: {
- "focus": function($event) {
- _vm.focus = true
- },
- "blur": function($event) {
- _vm.focus = false
- },
- "__c": function($event) {
- _vm.model = _vm.label
- }
+ "after-leave": _vm.doDestroy
}
- })]), _c('span', {
- staticClass: "el-radio__label"
- }, [_vm._t("default"), (!_vm.$slots.default) ? [_vm._v(_vm._s(_vm.label))] : _vm._e()], 2)])
+ }, [_c('ul', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.showPopper),
+ expression: "showPopper"
+ }],
+ staticClass: "el-dropdown-menu"
+ }, [_vm._t("default")], 2)])
},staticRenderFns: []}
/***/ },
-/* 75 */
+/* 37 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _radioGroup = __webpack_require__(76);
+ var _dropdownItem = __webpack_require__(38);
- var _radioGroup2 = _interopRequireDefault(_radioGroup);
+ var _dropdownItem2 = _interopRequireDefault(_dropdownItem);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _radioGroup2.default.install = function (Vue) {
- Vue.component(_radioGroup2.default.name, _radioGroup2.default);
+ _dropdownItem2.default.install = function (Vue) {
+ Vue.component(_dropdownItem2.default.name, _dropdownItem2.default);
};
- exports.default = _radioGroup2.default;
+ exports.default = _dropdownItem2.default;
/***/ },
-/* 76 */
+/* 38 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(77),
+ __webpack_require__(39),
/* template */
- __webpack_require__(78),
+ __webpack_require__(40),
/* styles */
null,
/* scopeId */
@@ -38117,7 +37627,7 @@ module.exports =
/***/ },
-/* 77 */
+/* 39 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
@@ -38131,23 +37641,19 @@ module.exports =
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElRadioGroup',
-
- componentName: 'ElRadioGroup',
+ name: 'ElDropdownItem',
mixins: [_emitter2.default],
props: {
- value: {},
- size: String,
- fill: String,
- textColor: String,
- disabled: Boolean
+ command: {},
+ disabled: Boolean,
+ divided: Boolean
},
- watch: {
- value: function value(_value) {
- this.$emit('change', _value);
- this.dispatch('ElFormItem', 'el.form.change', [this.value]);
+
+ methods: {
+ handleClick: function handleClick(e) {
+ this.dispatch('ElDropdown', 'menu-item-click', [this.command, this]);
}
}
}; //
@@ -38155,47 +37661,61 @@ module.exports =
//
//
//
+ //
+ //
+ //
+ //
+ //
+ //
+ //
/***/ },
-/* 78 */
+/* 40 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-radio-group"
+ return _c('li', {
+ staticClass: "el-dropdown-menu__item",
+ class: {
+ 'is-disabled': _vm.disabled,
+ 'el-dropdown-menu__item--divided': _vm.divided
+ },
+ on: {
+ "click": _vm.handleClick
+ }
}, [_vm._t("default")], 2)
},staticRenderFns: []}
/***/ },
-/* 79 */
+/* 41 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _radioButton = __webpack_require__(80);
+ var _menu = __webpack_require__(42);
- var _radioButton2 = _interopRequireDefault(_radioButton);
+ var _menu2 = _interopRequireDefault(_menu);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _radioButton2.default.install = function (Vue) {
- Vue.component(_radioButton2.default.name, _radioButton2.default);
+ _menu2.default.install = function (Vue) {
+ Vue.component(_menu2.default.name, _menu2.default);
};
- exports.default = _radioButton2.default;
+ exports.default = _menu2.default;
/***/ },
-/* 80 */
+/* 42 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(81),
+ __webpack_require__(43),
/* template */
- __webpack_require__(82),
+ __webpack_require__(45),
/* styles */
null,
/* scopeId */
@@ -38208,20 +37728,21 @@ module.exports =
/***/ },
-/* 81 */
-/***/ function(module, exports) {
+/* 43 */
+/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
+
+ var _emitter = __webpack_require__(15);
+
+ var _emitter2 = _interopRequireDefault(_emitter);
+
+ var _dom = __webpack_require__(44);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
//
//
//
@@ -38238,122 +37759,266 @@ module.exports =
//
exports.default = {
- name: 'ElRadioButton',
+ name: 'ElMenu',
+
+ componentName: 'ElMenu',
+
+ mixins: [_emitter2.default],
+
+ 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) {
+ (0, _dom.addClass)(el, 'el-opacity-transition');
+ el.style.opacity = 1;
+ },
+ afterEnter: function afterEnter(el) {
+ (0, _dom.removeClass)(el, 'el-opacity-transition');
+ el.style.opacity = '';
+ },
+ beforeLeave: function beforeLeave(el) {
+ if (!el.dataset) el.dataset = {};
+
+ if ((0, _dom.hasClass)(el, 'el-menu--collapse')) {
+ (0, _dom.removeClass)(el, 'el-menu--collapse');
+ el.dataset.oldOverflow = el.style.overflow;
+ el.dataset.scrollWidth = el.scrollWidth;
+ (0, _dom.addClass)(el, 'el-menu--collapse');
+ }
+
+ el.style.width = el.scrollWidth + 'px';
+ el.style.overflow = 'hidden';
+ },
+ leave: function leave(el) {
+ if (!(0, _dom.hasClass)(el, 'el-menu--collapse')) {
+ (0, _dom.addClass)(el, 'horizontal-collapse-transition');
+ el.style.width = '64px';
+ } else {
+ (0, _dom.addClass)(el, 'horizontal-collapse-transition');
+ el.style.width = el.dataset.scrollWidth + 'px';
+ }
+ },
+ afterLeave: function afterLeave(el) {
+ (0, _dom.removeClass)(el, 'horizontal-collapse-transition');
+ if ((0, _dom.hasClass)(el, 'el-menu--collapse')) {
+ el.style.width = el.dataset.scrollWidth + 'px';
+ } else {
+ el.style.width = '64px';
+ }
+ el.style.overflow = el.dataset.oldOverflow;
+ }
+ }
+ };
+ return createElement('transition', data, context.children);
+ }
+ }
+ },
props: {
- label: {},
- disabled: Boolean,
- name: String
+ mode: {
+ type: String,
+ default: 'vertical'
+ },
+ defaultActive: {
+ type: String,
+ default: ''
+ },
+ defaultOpeneds: Array,
+ theme: {
+ type: String,
+ default: 'light'
+ },
+ uniqueOpened: Boolean,
+ router: Boolean,
+ menuTrigger: {
+ type: String,
+ default: 'hover'
+ },
+ collapse: Boolean
},
- computed: {
- value: {
- get: function get() {
- return this._radioGroup.value;
- },
- set: function set(value) {
- this._radioGroup.$emit('input', value);
+ data: function data() {
+ return {
+ activeIndex: this.defaultActive,
+ openedMenus: this.defaultOpeneds ? this.defaultOpeneds.slice(0) : [],
+ items: {},
+ submenus: {}
+ };
+ },
+
+ watch: {
+ defaultActive: function defaultActive(value) {
+ var item = this.items[value];
+ if (item) {
+ this.activeIndex = item.index;
+ this.initOpenedMenu();
+ } else {
+ this.activeIndex = '';
}
},
- _radioGroup: function _radioGroup() {
- var parent = this.$parent;
- while (parent) {
- if (parent.$options.componentName !== 'ElRadioGroup') {
- parent = parent.$parent;
- } else {
- return parent;
- }
+ defaultOpeneds: function defaultOpeneds(value) {
+ this.openedMenus = value;
+ },
+ collapse: function collapse(value) {
+ if (value) this.openedMenus = [];
+ }
+ },
+ methods: {
+ 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;
+ // 将不在该菜单路径下的其余菜单收起
+ if (this.uniqueOpened) {
+ this.openedMenus = openedMenus.filter(function (index) {
+ return indexPath.indexOf(index) !== -1;
+ });
}
- return false;
+ this.openedMenus.push(index);
},
- 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 || ''
- };
+ closeMenu: function closeMenu(index) {
+ this.openedMenus.splice(this.openedMenus.indexOf(index), 1);
},
- size: function size() {
- return this._radioGroup.size;
+ 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);
+ }
},
- isDisabled: function isDisabled() {
- return this.disabled || this._radioGroup.disabled;
+ handleItemClick: function handleItemClick(item) {
+ var index = item.index,
+ indexPath = item.indexPath;
+
+ this.activeIndex = item.index;
+ this.$emit('select', index, indexPath, item);
+
+ if (this.mode === 'horizontal' || this.collapse) {
+ this.openedMenus = [];
+ }
+
+ if (this.router) {
+ this.routeToItem(item);
+ }
+ },
+
+ // 初始化展开菜单
+ initOpenedMenu: function initOpenedMenu() {
+ var _this = this;
+
+ var index = this.activeIndex;
+ var activeItem = this.items[index];
+ if (!activeItem || this.mode === 'horizontal' || this.collapse) return;
+
+ var indexPath = activeItem.indexPath;
+
+ // 展开该菜单项的路径上所有子菜单
+ indexPath.forEach(function (index) {
+ var submenu = _this.submenus[index];
+ submenu && _this.openMenu(index, submenu.indexPath);
+ });
+ },
+ routeToItem: function routeToItem(item) {
+ var route = item.route || item.index;
+ try {
+ this.$router.push(route);
+ } catch (e) {
+ console.error(e);
+ }
}
+ },
+ mounted: function mounted() {
+ this.initOpenedMenu();
+ this.$on('item-click', this.handleItemClick);
+ this.$on('submenu-click', this.handleSubmenuClick);
}
};
/***/ },
-/* 82 */
+/* 44 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(4);
+
+/***/ },
+/* 45 */
/***/ function(module, exports) {
module.exports={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
- }
- ]
- }, [_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
- },
- domProps: {
- "value": _vm.label,
- "checked": _vm._q(_vm.value, _vm.label)
- },
- on: {
- "__c": function($event) {
- _vm.value = _vm.label
- }
+ return _c('el-menu-collapse-transition', [_c('ul', {
+ key: +_vm.collapse,
+ staticClass: "el-menu",
+ class: {
+ 'el-menu--horizontal': _vm.mode === 'horizontal',
+ 'el-menu--dark': _vm.theme === 'dark',
+ 'el-menu--collapse': _vm.collapse
}
- }), _c('span', {
- staticClass: "el-radio-button__inner",
- style: (_vm.value === _vm.label ? _vm.activeStyle : null)
- }, [_vm._t("default"), (!_vm.$slots.default) ? [_vm._v(_vm._s(_vm.label))] : _vm._e()], 2)])
+ }, [_vm._t("default")], 2)])
},staticRenderFns: []}
/***/ },
-/* 83 */
+/* 46 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _checkbox = __webpack_require__(84);
+ var _submenu = __webpack_require__(47);
- var _checkbox2 = _interopRequireDefault(_checkbox);
+ var _submenu2 = _interopRequireDefault(_submenu);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _checkbox2.default.install = function (Vue) {
- Vue.component(_checkbox2.default.name, _checkbox2.default);
+ _submenu2.default.install = function (Vue) {
+ Vue.component(_submenu2.default.name, _submenu2.default);
};
- exports.default = _checkbox2.default;
+ exports.default = _submenu2.default;
/***/ },
-/* 84 */
+/* 47 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(85),
+ __webpack_require__(48),
/* template */
- __webpack_require__(86),
+ __webpack_require__(51),
/* styles */
null,
/* scopeId */
@@ -38366,13 +38031,21 @@ module.exports =
/***/ },
-/* 85 */
+/* 48 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
+ var _collapseTransition = __webpack_require__(49);
+
+ var _collapseTransition2 = _interopRequireDefault(_collapseTransition);
+
+ var _menuMixin = __webpack_require__(50);
+
+ var _menuMixin2 = _interopRequireDefault(_menuMixin);
+
var _emitter = __webpack_require__(15);
var _emitter2 = _interopRequireDefault(_emitter);
@@ -38380,99 +38053,115 @@ module.exports =
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElCheckbox',
+ name: 'ElSubmenu',
- mixins: [_emitter2.default],
+ componentName: 'ElSubmenu',
- componentName: 'ElCheckbox',
+ mixins: [_menuMixin2.default, _emitter2.default],
+
+ components: { ElCollapseTransition: _collapseTransition2.default },
+
+ props: {
+ index: {
+ type: String,
+ required: true
+ }
+ },
data: function data() {
return {
- selfModel: false,
- focus: false
+ timeout: null,
+ items: {},
+ submenus: {}
};
},
-
computed: {
- model: {
+ 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: {
+ cache: false,
get: function get() {
- return this.isGroup ? this.store : this.value !== undefined ? this.value : this.selfModel;
- },
- set: function set(val) {
- if (this.isGroup) {
- var isLimitExceeded = false;
- this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (isLimitExceeded = true);
+ var isActive = false;
+ var submenus = this.submenus;
+ var items = this.items;
- this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (isLimitExceeded = true);
+ Object.keys(items).forEach(function (index) {
+ if (items[index].active) {
+ isActive = true;
+ }
+ });
- isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]);
- } else {
- this.$emit('input', val);
- this.selfModel = val;
- }
- }
- },
+ Object.keys(submenus).forEach(function (index) {
+ if (submenus[index].active) {
+ isActive = true;
+ }
+ });
- 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;
+ return isActive;
}
+ }
+ },
+ methods: {
+ addItem: function addItem(item) {
+ this.$set(this.items, item.index, item);
},
- isGroup: function isGroup() {
- var parent = this.$parent;
- while (parent) {
- if (parent.$options.componentName !== 'ElCheckboxGroup') {
- parent = parent.$parent;
- } else {
- this._checkboxGroup = parent;
- return true;
- }
+ 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;
+
+ if (rootMenu.menuTrigger === 'hover' && rootMenu.mode === 'horizontal' || rootMenu.collapse && rootMenu.mode === 'vertical') {
+ return;
}
- return false;
+ this.dispatch('ElMenu', 'submenu-click', this);
},
- store: function store() {
- return this._checkboxGroup ? this._checkboxGroup.value : this.value;
- }
- },
+ handleMouseenter: function handleMouseenter() {
+ var _this = this;
- props: {
- value: {},
- label: {},
- indeterminate: Boolean,
- disabled: Boolean,
- checked: Boolean,
- name: String,
- trueLabel: [String, Number],
- falseLabel: [String, Number]
- },
+ var rootMenu = this.rootMenu;
- 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;
+ if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical') {
+ return;
}
+ clearTimeout(this.timeout);
+ this.timeout = setTimeout(function () {
+ _this.rootMenu.openMenu(_this.index, _this.indexPath);
+ }, 300);
},
- handleChange: function handleChange(ev) {
- var _this = this;
+ handleMouseleave: function handleMouseleave() {
+ var _this2 = this;
- this.$emit('change', ev);
- if (this.isGroup) {
- this.$nextTick(function (_) {
- _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]);
- });
+ var rootMenu = this.rootMenu;
+
+ if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical') {
+ return;
}
+ clearTimeout(this.timeout);
+ this.timeout = setTimeout(function () {
+ _this2.rootMenu.closeMenu(_this2.index);
+ }, 300);
}
},
-
created: function created() {
- this.checked && this.addToStore();
+ this.parentMenu.addSubmenu(this);
+ this.rootMenu.addSubmenu(this);
+ },
+ beforeDestroy: function beforeDestroy() {
+ this.parentMenu.removeSubmenu(this);
+ this.rootMenu.removeSubmenu(this);
}
}; //
//
@@ -38504,155 +38193,150 @@ module.exports =
//
//
//
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
/***/ },
-/* 86 */
+/* 49 */
/***/ function(module, exports) {
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('label', {
- staticClass: "el-checkbox"
- }, [_c('span', {
- staticClass: "el-checkbox__input",
- class: {
- 'is-disabled': _vm.disabled,
- 'is-checked': _vm.isChecked,
- 'is-indeterminate': _vm.indeterminate,
- 'is-focus': _vm.focus
- }
- }, [_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",
- "name": _vm.name,
- "disabled": _vm.disabled,
- "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": _vm.handleChange,
- "focus": function($event) {
- _vm.focus = true
- },
- "blur": function($event) {
- _vm.focus = false
- },
- "__c": 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 ($$c) {
- $$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
+ module.exports = __webpack_require__(51);
+
+/***/ },
+/* 50 */
+/***/ function(module, exports) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+ exports.default = {
+ 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;
}
- }
- }) : _c('input', {
- directives: [{
- name: "model",
- rawName: "v-model",
- value: (_vm.model),
- expression: "model"
- }],
- staticClass: "el-checkbox__original",
- attrs: {
- "type": "checkbox",
- "disabled": _vm.disabled,
- "name": _vm.name
+ return path;
},
- domProps: {
- "value": _vm.label,
- "checked": Array.isArray(_vm.model) ? _vm._i(_vm.model, _vm.label) > -1 : (_vm.model)
+ rootMenu: function rootMenu() {
+ var parent = this.$parent;
+ while (parent && parent.$options.componentName !== 'ElMenu') {
+ parent = parent.$parent;
+ }
+ return parent;
},
- on: {
- "change": _vm.handleChange,
- "focus": function($event) {
- _vm.focus = true
- },
- "blur": function($event) {
- _vm.focus = false
- },
- "__c": 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 ($$c) {
- $$i < 0 && (_vm.model = $$a.concat($$v))
- } else {
- $$i > -1 && (_vm.model = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))
+ 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;
}
- } else {
- _vm.model = $$c
+ parent = parent.$parent;
}
}
+ return { paddingLeft: padding + 'px' };
}
- })]), (_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()])
+ }
+ };
+
+/***/ },
+/* 51 */
+/***/ function(module, exports) {
+
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('li', {
+ class: {
+ 'el-submenu': true,
+ 'is-active': _vm.active,
+ 'is-opened': _vm.opened
+ },
+ on: {
+ "mouseenter": _vm.handleMouseenter,
+ "mouseleave": _vm.handleMouseleave
+ }
+ }, [_c('div', {
+ ref: "submenu-title",
+ staticClass: "el-submenu__title",
+ style: (_vm.paddingStyle),
+ on: {
+ "click": _vm.handleClick
+ }
+ }, [_vm._t("title"), _c('i', {
+ class: {
+ 'el-submenu__icon-arrow': true,
+ 'el-icon-caret-bottom': _vm.rootMenu.mode === 'horizontal',
+ 'el-icon-arrow-down': _vm.rootMenu.mode === 'vertical' && !_vm.rootMenu.collapse,
+ 'el-icon-caret-right': _vm.rootMenu.mode === 'vertical' && _vm.rootMenu.collapse
+ }
+ })], 2), (_vm.rootMenu.mode === 'horizontal' || (_vm.rootMenu.mode === 'vertical' && _vm.rootMenu.collapse)) ? [_c('transition', {
+ attrs: {
+ "name": _vm.menuTransitionName
+ }
+ }, [_c('ul', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.opened),
+ expression: "opened"
+ }],
+ staticClass: "el-menu"
+ }, [_vm._t("default")], 2)])] : _c('el-collapse-transition', [_c('ul', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.opened),
+ expression: "opened"
+ }],
+ staticClass: "el-menu"
+ }, [_vm._t("default")], 2)])], 2)
},staticRenderFns: []}
/***/ },
-/* 87 */
+/* 52 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _checkboxButton = __webpack_require__(88);
+ var _menuItem = __webpack_require__(53);
- var _checkboxButton2 = _interopRequireDefault(_checkboxButton);
+ var _menuItem2 = _interopRequireDefault(_menuItem);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _checkboxButton2.default.install = function (Vue) {
- Vue.component(_checkboxButton2.default.name, _checkboxButton2.default);
+ _menuItem2.default.install = function (Vue) {
+ Vue.component(_menuItem2.default.name, _menuItem2.default);
};
- exports.default = _checkboxButton2.default;
+ exports.default = _menuItem2.default;
/***/ },
-/* 88 */
+/* 53 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(89),
+ __webpack_require__(54),
/* template */
- __webpack_require__(90),
+ __webpack_require__(55),
/* styles */
null,
/* scopeId */
@@ -38665,140 +38349,23 @@ module.exports =
/***/ },
-/* 89 */
+/* 54 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
+ var _menuMixin = __webpack_require__(50);
+
+ var _menuMixin2 = _interopRequireDefault(_menuMixin);
+
var _emitter = __webpack_require__(15);
var _emitter2 = _interopRequireDefault(_emitter);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- exports.default = {
- name: 'ElCheckboxButton',
-
- mixins: [_emitter2.default],
-
- data: function data() {
- return {
- selfModel: false,
- focus: 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) {
- var isLimitExceeded = false;
- this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (isLimitExceeded = true);
-
- this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (isLimitExceeded = true);
-
- 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
-
- };
- },
- size: function size() {
- return this._checkboxGroup.size;
- }
- },
- 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;
-
- this.$emit('change', ev);
- if (this._checkboxGroup) {
- this.$nextTick(function (_) {
- _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]);
- });
- }
- }
- },
-
- created: function created() {
- this.checked && this.addToStore();
- }
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
//
//
//
@@ -38823,142 +38390,114 @@ module.exports =
//
//
+ exports.default = {
+ name: 'ElMenuItem',
+
+ componentName: 'ElMenuItem',
+
+ mixins: [_menuMixin2.default, _emitter2.default],
+
+ props: {
+ index: {
+ type: String,
+ required: true
+ },
+ route: {
+ type: Object,
+ required: false
+ },
+ disabled: {
+ type: Boolean,
+ required: false
+ }
+ },
+ computed: {
+ active: function active() {
+ return this.index === this.rootMenu.activeIndex;
+ }
+ },
+ methods: {
+ handleClick: function handleClick() {
+ this.dispatch('ElMenu', 'item-click', this);
+ this.$emit('click', this);
+ }
+ },
+ created: function created() {
+ this.parentMenu.addItem(this);
+ this.rootMenu.addItem(this);
+ },
+ beforeDestroy: function beforeDestroy() {
+ this.parentMenu.removeItem(this);
+ this.rootMenu.removeItem(this);
+ }
+ };
+
/***/ },
-/* 90 */
+/* 55 */
/***/ function(module, exports) {
module.exports={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.disabled
- }, {
- 'is-checked': _vm.isChecked
- }, {
- 'is-focus': _vm.focus
- } ]
- }, [(_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.disabled,
- "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)
+ return _c('li', {
+ staticClass: "el-menu-item",
+ class: {
+ 'is-active': _vm.active,
+ 'is-disabled': _vm.disabled
},
+ style: (_vm.paddingStyle),
on: {
- "change": _vm.handleChange,
- "focus": function($event) {
- _vm.focus = true
- },
- "blur": function($event) {
- _vm.focus = false
- },
- "__c": 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 ($$c) {
- $$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
- }
- }
+ "click": _vm.handleClick
}
- }) : _c('input', {
- directives: [{
- name: "model",
- rawName: "v-model",
- value: (_vm.model),
- expression: "model"
- }],
- staticClass: "el-checkbox-button__original",
+ }, [(_vm.$parent === _vm.rootMenu && _vm.rootMenu.collapse) ? _c('el-tooltip', {
attrs: {
- "type": "checkbox",
- "name": _vm.name,
- "disabled": _vm.disabled
- },
- domProps: {
- "value": _vm.label,
- "checked": Array.isArray(_vm.model) ? _vm._i(_vm.model, _vm.label) > -1 : (_vm.model)
- },
- on: {
- "change": _vm.handleChange,
- "focus": function($event) {
- _vm.focus = true
- },
- "blur": function($event) {
- _vm.focus = false
- },
- "__c": 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 ($$c) {
- $$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
- }
- }
+ "effect": "dark",
+ "placement": "right"
}
- }), (_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()])
+ }, [_c('div', {
+ 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)
},staticRenderFns: []}
/***/ },
-/* 91 */
+/* 56 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _checkboxGroup = __webpack_require__(92);
+ var _menuItemGroup = __webpack_require__(57);
- var _checkboxGroup2 = _interopRequireDefault(_checkboxGroup);
+ var _menuItemGroup2 = _interopRequireDefault(_menuItemGroup);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _checkboxGroup2.default.install = function (Vue) {
- Vue.component(_checkboxGroup2.default.name, _checkboxGroup2.default);
+ _menuItemGroup2.default.install = function (Vue) {
+ Vue.component(_menuItemGroup2.default.name, _menuItemGroup2.default);
};
- exports.default = _checkboxGroup2.default;
+ exports.default = _menuItemGroup2.default;
/***/ },
-/* 92 */
+/* 57 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(93),
+ __webpack_require__(58),
/* template */
- __webpack_require__(94),
+ __webpack_require__(59),
/* styles */
null,
/* scopeId */
@@ -38971,82 +38510,103 @@ module.exports =
/***/ },
-/* 93 */
-/***/ function(module, exports, __webpack_require__) {
+/* 58 */
+/***/ function(module, exports) {
'use strict';
exports.__esModule = true;
-
- var _emitter = __webpack_require__(15);
-
- var _emitter2 = _interopRequireDefault(_emitter);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
exports.default = {
- name: 'ElCheckboxGroup',
-
- componentName: 'ElCheckboxGroup',
+ name: 'ElMenuItemGroup',
- mixins: [_emitter2.default],
+ componentName: 'ElMenuItemGroup',
+ inject: ['rootMenu'],
props: {
- value: {},
- min: Number,
- max: Number,
- size: String,
- fill: String,
- textColor: String
+ title: {
+ type: String
+ }
+ },
+ data: function data() {
+ return {
+ paddingLeft: 20
+ };
},
- watch: {
- value: function value(_value) {
- this.dispatch('ElFormItem', 'el.form.change', [_value]);
+ computed: {
+ levelPadding: function levelPadding() {
+ var padding = 10;
+ 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;
+ }
+ padding === 10 && (padding = 20);
+ return padding;
}
}
};
/***/ },
-/* 94 */
+/* 59 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-checkbox-group"
- }, [_vm._t("default")], 2)
+ 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)])
},staticRenderFns: []}
/***/ },
-/* 95 */
+/* 60 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _component = __webpack_require__(96);
+ var _input = __webpack_require__(61);
- var _component2 = _interopRequireDefault(_component);
+ var _input2 = _interopRequireDefault(_input);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _component2.default.install = function (Vue) {
- Vue.component(_component2.default.name, _component2.default);
+ _input2.default.install = function (Vue) {
+ Vue.component(_input2.default.name, _input2.default);
};
- exports.default = _component2.default;
+ exports.default = _input2.default;
/***/ },
-/* 96 */
+/* 61 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(97),
+ __webpack_require__(62),
/* template */
- __webpack_require__(98),
+ __webpack_require__(65),
/* styles */
null,
/* scopeId */
@@ -39059,326 +38619,153 @@ module.exports =
/***/ },
-/* 97 */
-/***/ function(module, exports) {
+/* 62 */
+/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+
+ var _emitter = __webpack_require__(15);
+
+ var _emitter2 = _interopRequireDefault(_emitter);
+
+ var _calcTextareaHeight = __webpack_require__(63);
+
+ var _calcTextareaHeight2 = _interopRequireDefault(_calcTextareaHeight);
+
+ var _merge = __webpack_require__(64);
+
+ var _merge2 = _interopRequireDefault(_merge);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElSwitch',
+ name: 'ElInput',
+
+ componentName: 'ElInput',
+
+ mixins: [_emitter2.default],
+
+ data: function data() {
+ return {
+ currentValue: this.value,
+ textareaCalcStyle: {}
+ };
+ },
+
+
props: {
- value: {
- type: [Boolean, String, Number],
- default: false
+ value: [String, Number],
+ placeholder: String,
+ size: String,
+ resize: String,
+ readonly: Boolean,
+ autofocus: Boolean,
+ icon: String,
+ disabled: Boolean,
+ type: {
+ type: String,
+ default: 'text'
},
- disabled: {
- type: Boolean,
+ name: String,
+ autosize: {
+ type: [Boolean, Object],
default: false
},
- width: {
+ rows: {
type: Number,
- default: 0
- },
- onIconClass: {
- type: String,
- default: ''
- },
- offIconClass: {
- type: String,
- default: ''
- },
- onText: {
- type: String,
- default: 'ON'
- },
- offText: {
- type: String,
- default: 'OFF'
- },
- onColor: {
- type: String,
- default: ''
+ default: 2
},
- offColor: {
+ autoComplete: {
type: String,
- default: ''
+ default: 'off'
},
- onValue: {
- type: [Boolean, String, Number],
+ form: String,
+ maxlength: Number,
+ minlength: Number,
+ max: {},
+ min: {},
+ step: {},
+ validateEvent: {
+ type: Boolean,
default: true
},
- offValue: {
- type: [Boolean, String, Number],
- default: false
- },
- name: {
- type: String,
- default: ''
- }
- },
- data: function data() {
- return {
- coreWidth: this.width
- };
- },
- created: function created() {
- if (!~[this.onValue, this.offValue].indexOf(this.value)) {
- this.$emit('input', this.offValue);
- }
+ onIconClick: Function
},
computed: {
- checked: function checked() {
- return this.value === this.onValue;
- },
- hasText: function hasText() {
- /* istanbul ignore next */
- return this.onText || this.offText;
+ validating: function validating() {
+ return this.$parent.validateState === 'validating';
},
- transform: function transform() {
- return this.checked ? 'translate(' + (this.coreWidth - 20) + 'px, 2px)' : 'translate(2px, 2px)';
+ textareaStyle: function textareaStyle() {
+ return (0, _merge2.default)({}, this.textareaCalcStyle, { resize: this.resize });
}
},
+
watch: {
- checked: function checked() {
- this.$refs.input.checked = this.checked;
- if (this.onColor || this.offColor) {
- this.setBackgroundColor();
- }
+ 'value': function value(val, oldValue) {
+ this.setCurrentValue(val);
}
},
+
methods: {
- handleChange: function handleChange(event) {
+ handleBlur: function handleBlur(event) {
+ this.$emit('blur', event);
+ if (this.validateEvent) {
+ this.dispatch('ElFormItem', 'el.form.blur', [this.currentValue]);
+ }
+ },
+ inputSelect: function inputSelect() {
+ this.$refs.input.select();
+ },
+ resizeTextarea: function resizeTextarea() {
+ if (this.$isServer) return;
+ var autosize = this.autosize,
+ type = this.type;
+
+ if (!autosize || type !== 'textarea') return;
+ var minRows = autosize.minRows;
+ var maxRows = autosize.maxRows;
+
+ this.textareaCalcStyle = (0, _calcTextareaHeight2.default)(this.$refs.textarea, minRows, maxRows);
+ },
+ handleFocus: function handleFocus(event) {
+ this.$emit('focus', event);
+ },
+ handleInput: function handleInput(event) {
+ var value = event.target.value;
+ this.$emit('input', value);
+ this.setCurrentValue(value);
+ this.$emit('change', value);
+ },
+ handleIconClick: function handleIconClick(event) {
+ if (this.onIconClick) {
+ this.onIconClick(event);
+ }
+ this.$emit('click', event);
+ },
+ setCurrentValue: function setCurrentValue(value) {
var _this = this;
- this.$emit('input', !this.checked ? this.onValue : this.offValue);
- this.$emit('change', !this.checked ? this.onValue : this.offValue);
- this.$nextTick(function () {
- // set input's checked property
- // in case parent refuses to change component's value
- _this.$refs.input.checked = _this.checked;
+ if (value === this.currentValue) return;
+ this.$nextTick(function (_) {
+ _this.resizeTextarea();
});
- },
- setBackgroundColor: function setBackgroundColor() {
- var newColor = this.checked ? this.onColor : this.offColor;
- this.$refs.core.style.borderColor = newColor;
- this.$refs.core.style.backgroundColor = newColor;
+ this.currentValue = value;
+ if (this.validateEvent) {
+ this.dispatch('ElFormItem', 'el.form.change', [value]);
+ }
}
},
+
+ created: function created() {
+ this.$on('inputSelect', this.inputSelect);
+ },
mounted: function mounted() {
- /* istanbul ignore if */
- if (this.width === 0) {
- this.coreWidth = this.hasText ? 58 : 46;
- }
- if (this.onColor || this.offColor) {
- this.setBackgroundColor();
- }
- this.$refs.input.checked = this.checked;
+ this.resizeTextarea();
}
- };
-
-/***/ },
-/* 98 */
-/***/ function(module, exports) {
-
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('label', {
- staticClass: "el-switch",
- class: {
- 'is-disabled': _vm.disabled, 'el-switch--wide': _vm.hasText, 'is-checked': _vm.checked
- }
- }, [_c('div', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.disabled),
- expression: "disabled"
- }],
- staticClass: "el-switch__mask"
- }), _c('input', {
- ref: "input",
- staticClass: "el-switch__input",
- attrs: {
- "type": "checkbox",
- "name": _vm.name,
- "true-value": _vm.onValue,
- "false-value": _vm.offValue,
- "disabled": _vm.disabled
- },
- on: {
- "change": _vm.handleChange
- }
- }), _c('span', {
- ref: "core",
- staticClass: "el-switch__core",
- style: ({
- 'width': _vm.coreWidth + 'px'
- })
- }, [_c('span', {
- staticClass: "el-switch__button",
- style: ({
- transform: _vm.transform
- })
- })]), _c('transition', {
- attrs: {
- "name": "label-fade"
- }
- }, [_c('div', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.checked),
- expression: "checked"
- }],
- staticClass: "el-switch__label el-switch__label--left",
- style: ({
- 'width': _vm.coreWidth + 'px'
- })
- }, [(_vm.onIconClass) ? _c('i', {
- class: [_vm.onIconClass]
- }) : _vm._e(), (!_vm.onIconClass && _vm.onText) ? _c('span', [_vm._v(_vm._s(_vm.onText))]) : _vm._e()])]), _c('transition', {
- attrs: {
- "name": "label-fade"
- }
- }, [_c('div', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (!_vm.checked),
- expression: "!checked"
- }],
- staticClass: "el-switch__label el-switch__label--right",
- style: ({
- 'width': _vm.coreWidth + 'px'
- })
- }, [(_vm.offIconClass) ? _c('i', {
- class: [_vm.offIconClass]
- }) : _vm._e(), (!_vm.offIconClass && _vm.offText) ? _c('span', [_vm._v(_vm._s(_vm.offText))]) : _vm._e()])])], 1)
- },staticRenderFns: []}
-
-/***/ },
-/* 99 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _select = __webpack_require__(100);
-
- var _select2 = _interopRequireDefault(_select);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _select2.default.install = function (Vue) {
- Vue.component(_select2.default.name, _select2.default);
- };
-
- exports.default = _select2.default;
-
-/***/ },
-/* 100 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(101),
- /* template */
- __webpack_require__(113),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
-
-/***/ },
-/* 101 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- 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; }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ }; //
//
//
//
@@ -39436,665 +38823,529 @@ module.exports =
//
//
- var _emitter = __webpack_require__(15);
-
- var _emitter2 = _interopRequireDefault(_emitter);
-
- var _locale = __webpack_require__(10);
+/***/ },
+/* 63 */
+/***/ function(module, exports) {
- var _locale2 = _interopRequireDefault(_locale);
+ 'use strict';
- var _input = __webpack_require__(20);
+ exports.__esModule = true;
+ exports.default = calcTextareaHeight;
+ var hiddenTextarea = void 0;
- var _input2 = _interopRequireDefault(_input);
+ 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 _selectDropdown = __webpack_require__(102);
+ 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'];
- var _selectDropdown2 = _interopRequireDefault(_selectDropdown);
+ function calculateNodeStyling(targetElement) {
+ var style = window.getComputedStyle(targetElement);
- var _option = __webpack_require__(105);
+ var boxSizing = style.getPropertyValue('box-sizing');
- var _option2 = _interopRequireDefault(_option);
+ var paddingSize = parseFloat(style.getPropertyValue('padding-bottom')) + parseFloat(style.getPropertyValue('padding-top'));
- var _tag = __webpack_require__(109);
+ var borderSize = parseFloat(style.getPropertyValue('border-bottom-width')) + parseFloat(style.getPropertyValue('border-top-width'));
- var _tag2 = _interopRequireDefault(_tag);
+ var contextStyle = CONTEXT_STYLE.map(function (name) {
+ return name + ':' + style.getPropertyValue(name);
+ }).join(';');
- var _scrollbar = __webpack_require__(25);
+ return { contextStyle: contextStyle, paddingSize: paddingSize, borderSize: borderSize, boxSizing: boxSizing };
+ }
- var _scrollbar2 = _interopRequireDefault(_scrollbar);
+ function calcTextareaHeight(targetElement) {
+ var minRows = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
+ var maxRows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;
- var _debounce = __webpack_require__(69);
+ if (!hiddenTextarea) {
+ hiddenTextarea = document.createElement('textarea');
+ document.body.appendChild(hiddenTextarea);
+ }
- var _debounce2 = _interopRequireDefault(_debounce);
+ var _calculateNodeStyling = calculateNodeStyling(targetElement),
+ paddingSize = _calculateNodeStyling.paddingSize,
+ borderSize = _calculateNodeStyling.borderSize,
+ boxSizing = _calculateNodeStyling.boxSizing,
+ contextStyle = _calculateNodeStyling.contextStyle;
- var _clickoutside = __webpack_require__(21);
+ hiddenTextarea.setAttribute('style', contextStyle + ';' + HIDDEN_STYLE);
+ hiddenTextarea.value = targetElement.value || targetElement.placeholder || '';
- var _clickoutside2 = _interopRequireDefault(_clickoutside);
+ var height = hiddenTextarea.scrollHeight;
- var _dom = __webpack_require__(44);
+ if (boxSizing === 'border-box') {
+ height = height + borderSize;
+ } else if (boxSizing === 'content-box') {
+ height = height - paddingSize;
+ }
- var _resizeEvent = __webpack_require__(110);
+ hiddenTextarea.value = '';
+ var singleRowHeight = hiddenTextarea.scrollHeight - paddingSize;
- var _locale3 = __webpack_require__(111);
+ if (minRows !== null) {
+ var minHeight = singleRowHeight * minRows;
+ if (boxSizing === 'border-box') {
+ minHeight = minHeight + paddingSize + borderSize;
+ }
+ height = Math.max(minHeight, height);
+ }
+ if (maxRows !== null) {
+ var maxHeight = singleRowHeight * maxRows;
+ if (boxSizing === 'border-box') {
+ maxHeight = maxHeight + paddingSize + borderSize;
+ }
+ height = Math.min(maxHeight, height);
+ }
- var _scrollIntoView = __webpack_require__(112);
+ return { height: height + 'px' };
+ };
- var _scrollIntoView2 = _interopRequireDefault(_scrollIntoView);
+/***/ },
+/* 64 */
+/***/ function(module, exports) {
- var _util = __webpack_require__(107);
+ module.exports = __webpack_require__(12);
+
+/***/ },
+/* 65 */
+/***/ function(module, exports) {
+
+ module.exports={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.size ? 'el-input--' + _vm.size : '', {
+ 'is-disabled': _vm.disabled,
+ 'el-input-group': _vm.$slots.prepend || _vm.$slots.append,
+ 'el-input-group--append': _vm.$slots.append,
+ 'el-input-group--prepend': _vm.$slots.prepend
+ }
+ ]
+ }, [(_vm.type !== 'textarea') ? [(_vm.$slots.prepend) ? _c('div', {
+ staticClass: "el-input-group__prepend"
+ }, [_vm._t("prepend")], 2) : _vm._e(), _vm._t("icon", [(_vm.icon) ? _c('i', {
+ staticClass: "el-input__icon",
+ class: [
+ 'el-icon-' + _vm.icon,
+ _vm.onIconClick ? 'is-clickable' : ''
+ ],
+ on: {
+ "click": _vm.handleIconClick
+ }
+ }) : _vm._e()]), (_vm.type !== 'textarea') ? _c('input', _vm._b({
+ ref: "input",
+ staticClass: "el-input__inner",
+ attrs: {
+ "autocomplete": _vm.autoComplete
+ },
+ domProps: {
+ "value": _vm.currentValue
+ },
+ on: {
+ "input": _vm.handleInput,
+ "focus": _vm.handleFocus,
+ "blur": _vm.handleBlur
+ }
+ }, 'input', _vm.$props)) : _vm._e(), (_vm.validating) ? _c('i', {
+ staticClass: "el-input__icon el-icon-loading"
+ }) : _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),
+ domProps: {
+ "value": _vm.currentValue
+ },
+ on: {
+ "input": _vm.handleInput,
+ "focus": _vm.handleFocus,
+ "blur": _vm.handleBlur
+ }
+ }, 'textarea', _vm.$props))], 2)
+ },staticRenderFns: []}
+
+/***/ },
+/* 66 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _inputNumber = __webpack_require__(67);
+
+ var _inputNumber2 = _interopRequireDefault(_inputNumber);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var sizeMap = {
- 'large': 42,
- 'small': 30,
- 'mini': 22
+ /* istanbul ignore next */
+ _inputNumber2.default.install = function (Vue) {
+ Vue.component(_inputNumber2.default.name, _inputNumber2.default);
};
- exports.default = {
- mixins: [_emitter2.default, _locale2.default],
+ exports.default = _inputNumber2.default;
- name: 'ElSelect',
+/***/ },
+/* 67 */
+/***/ function(module, exports, __webpack_require__) {
- componentName: 'ElSelect',
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(68),
+ /* template */
+ __webpack_require__(70),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- computed: {
- iconClass: function iconClass() {
- var criteria = this.clearable && !this.disabled && this.inputHovering && !this.multiple && this.value !== undefined && this.value !== '';
- return criteria ? 'circle-close is-show-close' : this.remote && this.filterable ? '' : 'caret-top';
- },
- 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.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;
+ module.exports = Component.exports
- 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;
+
+/***/ },
+/* 68 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _input = __webpack_require__(20);
+
+ var _input2 = _interopRequireDefault(_input);
+
+ var _dom = __webpack_require__(44);
+
+ var _debounce = __webpack_require__(69);
+
+ var _debounce2 = _interopRequireDefault(_debounce);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ exports.default = {
+ name: 'ElInputNumber',
+ directives: {
+ repeatClick: {
+ 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 (new Date() - startTime < 100) {
+ handler();
+ }
+ clearInterval(interval);
+ interval = null;
+ };
+
+ (0, _dom.on)(el, 'mousedown', function () {
+ startTime = new Date();
+ (0, _dom.once)(document, 'mouseup', clear);
+ clearInterval(interval);
+ interval = setInterval(handler, 100);
+ });
+ }
}
},
-
components: {
- ElInput: _input2.default,
- ElSelectMenu: _selectDropdown2.default,
- ElOption: _option2.default,
- ElTag: _tag2.default,
- ElScrollbar: _scrollbar2.default
+ ElInput: _input2.default
},
-
- directives: { Clickoutside: _clickoutside2.default },
-
props: {
- name: String,
- value: {
- required: true
+ step: {
+ type: Number,
+ default: 1
},
- 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: {
+ max: {
+ type: Number,
+ default: Infinity
+ },
+ min: {
type: Number,
+ default: -Infinity
+ },
+ value: {
default: 0
},
- placeholder: {
- type: String,
- default: function _default() {
- return (0, _locale3.t)('el.select.placeholder');
- }
+ disabled: Boolean,
+ size: String,
+ controls: {
+ type: Boolean,
+ default: true
},
- defaultFirstOption: Boolean,
- valueKey: {
- type: String,
- default: 'value'
+ debounce: {
+ type: Number,
+ default: 300
}
},
-
data: function data() {
return {
- options: [],
- cachedOptions: [],
- createdLabel: null,
- createdSelected: false,
- selected: this.multiple ? [] : {},
- isSelect: true,
- inputLength: 20,
- inputWidth: 0,
- cachedPlaceHolder: '',
- optionsCount: 0,
- filteredOptionsCount: 0,
- visible: false,
- selectedLabel: '',
- hoverIndex: -1,
- query: '',
- optionsAllDisabled: false,
- inputHovering: false,
- currentPlaceholder: ''
+ currentValue: 0
};
},
-
watch: {
- placeholder: function placeholder(val) {
- this.cachedPlaceHolder = this.currentPlaceholder = val;
- },
- value: function value(val) {
- if (this.multiple) {
- this.resetInputHeight();
- if (val.length > 0 || this.$refs.input && this.query !== '') {
- this.currentPlaceholder = '';
- } else {
- this.currentPlaceholder = this.cachedPlaceHolder;
- }
- }
- this.setSelected();
- if (this.filterable && !this.multiple) {
- this.inputLength = 20;
+ value: {
+ immediate: true,
+ handler: function handler(value) {
+ var newVal = Number(value);
+ if (isNaN(newVal)) return;
+ if (newVal >= this.max) newVal = this.max;
+ if (newVal <= this.min) newVal = this.min;
+ this.currentValue = newVal;
+ this.$emit('input', newVal);
}
- this.$emit('change', val);
- this.dispatch('ElFormItem', 'el.form.change', val);
+ }
+ },
+ computed: {
+ minDisabled: function minDisabled() {
+ return this._decrease(this.value, this.step) < this.min;
},
- query: function query(val) {
- var _this2 = this;
-
- this.$nextTick(function () {
- if (_this2.visible) _this2.broadcast('ElSelectDropdown', 'updatePopper');
- });
- this.hoverIndex = -1;
- if (this.multiple && this.filterable) {
- this.inputLength = this.$refs.input.value.length * 15 + 20;
- this.managePlaceholder();
- this.resetInputHeight();
- }
- if (this.remote && typeof this.remoteMethod === 'function') {
- this.hoverIndex = -1;
- this.remoteMethod(val);
- this.broadcast('ElOption', 'resetIndex');
- } 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();
- }
+ maxDisabled: function maxDisabled() {
+ return this._increase(this.value, this.step) > this.max;
},
- visible: function visible(val) {
- var _this3 = this;
+ precision: function precision() {
+ var value = this.value,
+ step = this.step,
+ getPrecision = this.getPrecision;
- if (!val) {
- this.$refs.reference.$el.querySelector('input').blur();
- this.handleIconHide();
- this.broadcast('ElSelectDropdown', 'destroyPopper');
- if (this.$refs.input) {
- this.$refs.input.blur();
- }
- this.query = '';
- this.selectedLabel = '';
- this.inputLength = 20;
- 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.createdOption) {
- this.selectedLabel = this.createdLabel;
- } else {
- this.selectedLabel = this.selected.currentLabel;
- }
- if (this.filterable) this.query = this.selectedLabel;
- }
- }
- } else {
- this.handleIconShow();
- this.broadcast('ElSelectDropdown', 'updatePopper');
- if (this.filterable) {
- this.query = this.selectedLabel;
- if (this.multiple) {
- this.$refs.input.focus();
- } else {
- if (!this.remote) {
- this.broadcast('ElOption', 'queryChange', '');
- this.broadcast('ElOptionGroup', 'queryChange');
- }
- this.broadcast('ElInput', 'inputSelect');
- }
- }
- }
- this.$emit('visible-change', val);
- },
- options: function options(val) {
- if (this.$isServer) return;
- this.optionsAllDisabled = val.length === val.filter(function (item) {
- return item.disabled === true;
- }).length;
- 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();
- }
+ return Math.max(getPrecision(value), getPrecision(step));
}
},
-
methods: {
- handleIconHide: function handleIconHide() {
- var icon = this.$el.querySelector('.el-input__icon');
- if (icon) {
- (0, _dom.removeClass)(icon, 'is-reverse');
- }
+ toPrecision: function toPrecision(num, precision) {
+ if (precision === undefined) precision = this.precision;
+ return parseFloat(parseFloat(Number(num).toFixed(precision)));
},
- handleIconShow: function handleIconShow() {
- var icon = this.$el.querySelector('.el-input__icon');
- if (icon && !(0, _dom.hasClass)(icon, 'el-icon-circle-close')) {
- (0, _dom.addClass)(icon, 'is-reverse');
+ getPrecision: function getPrecision(value) {
+ var valueString = value.toString();
+ var dotPosition = valueString.indexOf('.');
+ var precision = 0;
+ if (dotPosition !== -1) {
+ precision = valueString.length - dotPosition - 1;
}
+ return precision;
},
- 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');
- (0, _scrollIntoView2.default)(menu, target);
- }
+ _increase: function _increase(val, step) {
+ if (typeof val !== 'number') return this.currentValue;
+
+ var precisionFactor = Math.pow(10, this.precision);
+
+ return this.toPrecision((precisionFactor * val + precisionFactor * step) / precisionFactor);
},
- handleMenuEnter: function handleMenuEnter() {
- var _this4 = this;
+ _decrease: function _decrease(val, step) {
+ if (typeof val !== 'number') return this.currentValue;
- this.$nextTick(function () {
- return _this4.scrollToOption(_this4.selected);
- });
+ var precisionFactor = Math.pow(10, this.precision);
+
+ return this.toPrecision((precisionFactor * val - precisionFactor * step) / precisionFactor);
},
- getOption: function getOption(value) {
- var option = void 0;
- var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
- for (var i = this.cachedOptions.length - 1; i >= 0; i--) {
- var cachedOption = this.cachedOptions[i];
- var isEqual = isObject ? (0, _util.getValueByPath)(cachedOption.value, this.valueKey) === (0, _util.getValueByPath)(value, this.valueKey) : cachedOption.value === value;
- if (isEqual) {
- option = cachedOption;
- break;
- }
- }
- if (option) return option;
- var label = !isObject ? value : '';
- var newOption = {
- value: value,
- currentLabel: label
- };
- if (this.multiple) {
- newOption.hitState = false;
- }
- return newOption;
+ increase: function increase() {
+ if (this.disabled || this.maxDisabled) return;
+ var value = this.value || 0;
+ var newVal = this._increase(value, this.step);
+ if (newVal > this.max) return;
+ this.setCurrentValue(newVal);
},
- setSelected: function setSelected() {
- var _this5 = 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;
+ decrease: function decrease() {
+ if (this.disabled || this.minDisabled) return;
+ var value = this.value || 0;
+ var newVal = this._decrease(value, this.step);
+ if (newVal < this.min) return;
+ this.setCurrentValue(newVal);
+ },
+ handleBlur: function handleBlur() {
+ this.$refs.input.setCurrentValue(this.currentValue);
+ },
+ setCurrentValue: function setCurrentValue(newVal) {
+ var oldVal = this.currentValue;
+ if (newVal >= this.max) newVal = this.max;
+ if (newVal <= this.min) newVal = this.min;
+ if (oldVal === newVal) {
+ this.$refs.input.setCurrentValue(this.currentValue);
return;
}
- var result = [];
- if (Array.isArray(this.value)) {
- this.value.forEach(function (value) {
- result.push(_this5.getOption(value));
- });
+ this.$emit('change', newVal, oldVal);
+ this.$emit('input', newVal);
+ this.currentValue = newVal;
+ },
+ handleInput: function handleInput(value) {
+ if (value === '') {
+ return;
}
- this.selected = result;
- this.$nextTick(function () {
- _this5.resetInputHeight();
- });
- },
- handleFocus: function handleFocus() {
- this.visible = true;
- },
- handleIconClick: function handleIconClick(event) {
- if (this.iconClass.indexOf('circle-close') > -1) {
- this.deleteSelected(event);
+ var newVal = Number(value);
+ if (!isNaN(newVal)) {
+ this.setCurrentValue(newVal);
} else {
- this.toggleMenu();
- }
- },
- handleMouseDown: function handleMouseDown(event) {
- if (event.target.tagName !== 'INPUT') return;
- if (this.visible) {
- this.handleClose();
- event.preventDefault();
- }
- },
- doDestroy: function doDestroy() {
- this.$refs.popper && this.$refs.popper.doDestroy();
- this.dropdownUl = null;
- },
- 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);
- }
- },
- managePlaceholder: function managePlaceholder() {
- if (this.currentPlaceholder !== '') {
- this.currentPlaceholder = this.$refs.input.value ? '' : this.cachedPlaceHolder;
+ this.$refs.input.setCurrentValue(this.currentValue);
}
- },
- 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 _this6 = this;
-
- this.$nextTick(function () {
- if (!_this6.$refs.reference) return;
- var inputChildNodes = _this6.$refs.reference.$el.childNodes;
- var input = [].filter.call(inputChildNodes, function (item) {
- return item.tagName === 'INPUT';
- })[0];
- input.style.height = Math.max(_this6.$refs.tags.clientHeight + 6, sizeMap[_this6.size] || 36) + 'px';
- if (_this6.visible && _this6.emptyText !== false) {
- _this6.broadcast('ElSelectDropdown', 'updatePopper');
- }
- });
- },
- resetHoverIndex: function resetHoverIndex() {
- var _this7 = this;
-
- setTimeout(function () {
- if (!_this7.multiple) {
- _this7.hoverIndex = _this7.options.indexOf(_this7.selected);
- } else {
- if (_this7.selected.length > 0) {
- _this7.hoverIndex = Math.min.apply(null, _this7.selected.map(function (item) {
- return _this7.options.indexOf(item);
- }));
- } else {
- _this7.hoverIndex = -1;
- }
- }
- }, 300);
- },
- handleOptionSelect: function handleOptionSelect(option) {
- var _this8 = this;
+ }
+ },
+ created: function created() {
+ var _this = 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);
- if (option.created) {
- this.query = '';
- this.inputLength = 20;
- }
- if (this.filterable) this.$refs.input.focus();
- } else {
- this.$emit('input', option.value);
- this.visible = false;
- }
- this.$nextTick(function () {
- return _this8.scrollToOption(option);
- });
- },
- getValueIndex: function getValueIndex() {
- var _this9 = this;
+ this.debounceHandleInput = (0, _debounce2.default)(this.debounce, function (value) {
+ _this.handleInput(value);
+ });
+ }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var value = arguments[1];
+/***/ },
+/* 69 */
+/***/ function(module, exports) {
- var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
- if (!isObject) {
- return arr.indexOf(value);
- } else {
- var _ret = function () {
- var valueKey = _this9.valueKey;
- var index = -1;
- arr.some(function (item, i) {
- if ((0, _util.getValueByPath)(item, valueKey) === (0, _util.getValueByPath)(value, valueKey)) {
- index = i;
- return true;
- }
- return false;
- });
- return {
- v: index
- };
- }();
+ module.exports = __webpack_require__(9);
- if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
- }
- },
- toggleMenu: function toggleMenu() {
- if (this.filterable && this.query === '' && this.visible) {
- return;
- }
- if (!this.disabled) {
- this.visible = !this.visible;
- }
- },
- navigateOptions: function navigateOptions(direction) {
- var _this10 = this;
+/***/ },
+/* 70 */
+/***/ function(module, exports) {
- if (!this.visible) {
- this.visible = true;
- return;
- }
- if (this.options.length === 0 || this.filteredOptionsCount === 0) return;
- this.optionsAllDisabled = this.options.length === this.options.filter(function (item) {
- return item.disabled === true;
- }).length;
- if (!this.optionsAllDisabled) {
- if (direction === 'next') {
- this.hoverIndex++;
- if (this.hoverIndex === this.options.length) {
- this.hoverIndex = 0;
- }
- if (this.options[this.hoverIndex].disabled === true || this.options[this.hoverIndex].groupDisabled === true || !this.options[this.hoverIndex].visible) {
- this.navigateOptions('next');
- }
- }
- if (direction === 'prev') {
- this.hoverIndex--;
- if (this.hoverIndex < 0) {
- this.hoverIndex = this.options.length - 1;
- }
- if (this.options[this.hoverIndex].disabled === true || this.options[this.hoverIndex].groupDisabled === true || !this.options[this.hoverIndex].visible) {
- this.navigateOptions('prev');
- }
- }
- }
- this.$nextTick(function () {
- return _this10.scrollToOption(_this10.options[_this10.hoverIndex]);
- });
- },
- selectOption: function selectOption() {
- if (this.options[this.hoverIndex]) {
- this.handleOptionSelect(this.options[this.hoverIndex]);
- }
- },
- deleteSelected: function deleteSelected(event) {
- event.stopPropagation();
- this.$emit('input', '');
- this.visible = false;
- this.$emit('clear');
- },
- deleteTag: function deleteTag(event, tag) {
- var index = this.selected.indexOf(tag);
- if (index > -1 && !this.disabled) {
- var value = this.value.slice();
- value.splice(index, 1);
- this.$emit('input', value);
- this.$emit('remove-tag', tag);
- }
- event.stopPropagation();
- },
- onInputChange: function onInputChange() {
- if (this.filterable) {
- this.query = this.selectedLabel;
- }
- },
- onOptionDestroy: function onOptionDestroy(option) {
- this.optionsCount--;
- this.filteredOptionsCount--;
- var index = this.options.indexOf(option);
- if (index > -1) {
- this.options.splice(index, 1);
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-input-number",
+ class: [
+ _vm.size ? 'el-input-number--' + _vm.size : '', {
+ 'is-disabled': _vm.disabled
+ }, {
+ 'is-without-controls': !_vm.controls
}
- this.broadcast('ElOption', 'resetIndex');
- },
- resetInputWidth: function resetInputWidth() {
- this.inputWidth = this.$refs.reference.$el.getBoundingClientRect().width;
- },
- handleResize: function handleResize() {
- this.resetInputWidth();
- if (this.multiple) this.resetInputHeight();
+ ]
+ }, [(_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
+ }
+ }, [_c('i', {
+ staticClass: "el-icon-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
+ }
+ }, [_c('i', {
+ staticClass: "el-icon-plus"
+ })]) : _vm._e(), _c('el-input', {
+ ref: "input",
+ attrs: {
+ "value": _vm.currentValue,
+ "disabled": _vm.disabled,
+ "size": _vm.size,
+ "max": _vm.max,
+ "min": _vm.min
},
- checkDefaultFirstOption: function checkDefaultFirstOption() {
- this.hoverIndex = -1;
- for (var i = 0; i !== this.options.length; ++i) {
- var option = this.options[i];
- if (this.query) {
- // pick first options that passes the filter
- if (!option.disabled && !option.groupDisabled && option.visible) {
- this.hoverIndex = i;
- break;
- }
- } else {
- // pick currently selected option
- if (option.itemSelected) {
- this.hoverIndex = i;
- break;
- }
- }
- }
+ on: {
+ "blur": _vm.handleBlur,
+ "input": _vm.debounceHandleInput
},
- getValueKey: function getValueKey(item) {
- var type = _typeof(item.value);
- if (type === 'number' || type === 'string') {
- return item.value;
- } else {
- return (0, _util.getValueByPath)(item.value, this.valueKey);
- }
+ nativeOn: {
+ "keydown": [function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
+ $event.preventDefault();
+ _vm.increase($event)
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
+ $event.preventDefault();
+ _vm.decrease($event)
+ }]
}
- },
+ }, [(_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()], 2)], 1)
+ },staticRenderFns: []}
- created: function created() {
- var _this11 = this;
+/***/ },
+/* 71 */
+/***/ function(module, exports, __webpack_require__) {
- 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.setSelected();
+ 'use strict';
- this.debouncedOnInputChange = (0, _debounce2.default)(this.debounce, function () {
- _this11.onInputChange();
- });
+ exports.__esModule = true;
- this.$on('handleOptionClick', this.handleOptionSelect);
- this.$on('onOptionDestroy', this.onOptionDestroy);
- this.$on('setSelected', this.setSelected);
- },
- mounted: function mounted() {
- var _this12 = this;
+ var _radio = __webpack_require__(72);
- if (this.multiple && Array.isArray(this.value) && this.value.length > 0) {
- this.currentPlaceholder = '';
- }
- (0, _resizeEvent.addResizeListener)(this.$el, this.handleResize);
- if (this.remote && this.multiple) {
- this.resetInputHeight();
- }
- this.$nextTick(function () {
- if (_this12.$refs.reference && _this12.$refs.reference.$el) {
- _this12.inputWidth = _this12.$refs.reference.$el.getBoundingClientRect().width;
- }
- });
- },
- beforeDestroy: function beforeDestroy() {
- if (this.$el && this.handleResize) (0, _resizeEvent.removeResizeListener)(this.$el, this.handleResize);
- }
+ var _radio2 = _interopRequireDefault(_radio);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _radio2.default.install = function (Vue) {
+ Vue.component('el-radio', _radio2.default);
};
+ exports.default = _radio2.default;
+
/***/ },
-/* 102 */
+/* 72 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(103),
+ __webpack_require__(73),
/* template */
- __webpack_require__(104),
+ __webpack_require__(74),
/* styles */
null,
/* scopeId */
@@ -40107,73 +39358,71 @@ module.exports =
/***/ },
-/* 103 */
+/* 73 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _vuePopper = __webpack_require__(24);
+ var _emitter = __webpack_require__(15);
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
+ var _emitter2 = _interopRequireDefault(_emitter);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElSelectDropdown',
+ name: 'ElRadio',
- componentName: 'ElSelectDropdown',
+ mixins: [_emitter2.default],
- mixins: [_vuePopper2.default],
+ componentName: 'ElRadio',
props: {
- placement: {
- default: 'bottom-start'
- },
-
- boundariesPadding: {
- default: 0
- },
-
- popperOptions: {
- default: function _default() {
- return {
- forceAbsolute: true,
- gpuAcceleration: false
- };
- }
- }
+ value: {},
+ label: {},
+ disabled: Boolean,
+ name: String
},
data: function data() {
return {
- minWidth: ''
+ focus: false
};
},
computed: {
- popperClass: function popperClass() {
- return this.$parent.popperClass;
- }
- },
+ 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;
+ },
- watch: {
- '$parent.inputWidth': function $parentInputWidth() {
- this.minWidth = this.$parent.$el.getBoundingClientRect().width + 'px';
- }
- },
- mounted: function mounted() {
- var _this = this;
+ 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.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);
+ isDisabled: function isDisabled() {
+ return this.isGroup ? this._radioGroup.disabled || this.disabled : this.disabled;
+ }
}
}; //
//
@@ -40184,52 +39433,6 @@ module.exports =
//
//
//
-
-/***/ },
-/* 104 */
-/***/ function(module, exports) {
-
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-select-dropdown",
- class: [{
- 'is-multiple': _vm.$parent.multiple
- }, _vm.popperClass],
- style: ({
- minWidth: _vm.minWidth
- })
- }, [_vm._t("default")], 2)
- },staticRenderFns: []}
-
-/***/ },
-/* 105 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(106),
- /* template */
- __webpack_require__(108),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
-
-/***/ },
-/* 106 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- 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; }; //
//
//
//
@@ -40246,472 +39449,87 @@ module.exports =
//
//
//
-
- var _emitter = __webpack_require__(15);
-
- var _emitter2 = _interopRequireDefault(_emitter);
-
- var _util = __webpack_require__(107);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = {
- mixins: [_emitter2.default],
-
- name: 'ElOption',
-
- componentName: 'ElOption',
-
- 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
- };
- },
-
-
- 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 || '';
- },
- parent: function parent() {
- var result = this.$parent;
- while (!result.isSelect) {
- result = result.$parent;
- }
- return result;
- },
- itemSelected: function itemSelected() {
- if (!this.parent.multiple) {
- return this.isEqual(this.value, this.parent.value);
- } else {
- return this.contains(this.parent.value, this.value);
- }
- },
- limitReached: function limitReached() {
- if (this.parent.multiple) {
- return !this.itemSelected && this.parent.value.length >= this.parent.multipleLimit && this.parent.multipleLimit > 0;
- } else {
- return false;
- }
- }
- },
-
- watch: {
- currentLabel: function currentLabel() {
- if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
- },
- value: function value() {
- if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
- }
- },
-
- methods: {
- isEqual: function isEqual(a, b) {
- if (!this.isObject) {
- return a === b;
- } else {
- var valueKey = this.parent.valueKey;
- return (0, _util.getValueByPath)(a, valueKey) === (0, _util.getValueByPath)(b, valueKey);
- }
- },
- contains: function contains() {
- var _this = this;
-
- var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var target = arguments[1];
-
- if (!this.isObject) {
- return arr.indexOf(target) > -1;
- } else {
- var _ret = function () {
- var valueKey = _this.parent.valueKey;
- return {
- v: arr.some(function (item) {
- return (0, _util.getValueByPath)(item, valueKey) === (0, _util.getValueByPath)(target, valueKey);
- })
- };
- }();
-
- if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
- }
- },
- handleGroupDisabled: function handleGroupDisabled(val) {
- this.groupDisabled = val;
- },
- hoverItem: function hoverItem() {
- if (!this.disabled && !this.groupDisabled) {
- this.parent.hoverIndex = this.parent.options.indexOf(this);
- }
- },
- selectOptionClick: function selectOptionClick() {
- if (this.disabled !== true && this.groupDisabled !== true) {
- this.dispatch('ElSelect', 'handleOptionClick', this);
- }
- },
- queryChange: function queryChange(query) {
- // query 里如果有正则中的特殊字符,需要先将这些字符转义
- var parsedQuery = String(query).replace(/(\^|\(|\)|\[|\]|\$|\*|\+|\.|\?|\\|\{|\}|\|)/g, '\\$1');
- this.visible = new RegExp(parsedQuery, 'i').test(this.currentLabel) || this.created;
- if (!this.visible) {
- this.parent.filteredOptionsCount--;
- }
- },
- resetIndex: function resetIndex() {
- var _this2 = this;
-
- this.$nextTick(function () {
- _this2.index = _this2.parent.options.indexOf(_this2);
- });
- }
- },
-
- created: function created() {
- this.parent.options.push(this);
- this.parent.cachedOptions.push(this);
- this.parent.optionsCount++;
- this.parent.filteredOptionsCount++;
- this.index = this.parent.options.indexOf(this);
-
- this.$on('queryChange', this.queryChange);
- this.$on('handleGroupDisabled', this.handleGroupDisabled);
- this.$on('resetIndex', this.resetIndex);
- },
- beforeDestroy: function beforeDestroy() {
- this.dispatch('ElSelect', 'onOptionDestroy', this);
- }
- };
-
-/***/ },
-/* 107 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(6);
+ //
/***/ },
-/* 108 */
+/* 74 */
/***/ function(module, exports) {
module.exports={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",
+ return _c('label', {
+ staticClass: "el-radio"
+ }, [_c('span', {
+ staticClass: "el-radio__input",
class: {
- 'selected': _vm.itemSelected,
- 'is-disabled': _vm.disabled || _vm.groupDisabled || _vm.limitReached,
- 'hover': _vm.parent.hoverIndex === _vm.index
- },
- on: {
- "mouseenter": _vm.hoverItem,
- "click": function($event) {
- $event.stopPropagation();
- _vm.selectOptionClick($event)
- }
- }
- }, [_vm._t("default", [_c('span', [_vm._v(_vm._s(_vm.currentLabel))])])], 2)
- },staticRenderFns: []}
-
-/***/ },
-/* 109 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(26);
-
-/***/ },
-/* 110 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(15);
-
-/***/ },
-/* 111 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(16);
-
-/***/ },
-/* 112 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(23);
-
-/***/ },
-/* 113 */
-/***/ function(module, exports) {
-
- module.exports={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"
- }, [(_vm.multiple) ? _c('div', {
- ref: "tags",
- staticClass: "el-select__tags",
- style: ({
- 'max-width': _vm.inputWidth - 32 + 'px'
- }),
- on: {
- "click": function($event) {
- $event.stopPropagation();
- _vm.toggleMenu($event)
- }
- }
- }, [_c('transition-group', {
- on: {
- "after-leave": _vm.resetInputHeight
+ 'is-disabled': _vm.isDisabled,
+ 'is-checked': _vm.model === _vm.label,
+ 'is-focus': _vm.focus
}
- }, _vm._l((_vm.selected), function(item) {
- return _c('el-tag', {
- key: _vm.getValueKey(item),
- attrs: {
- "closable": !_vm.disabled,
- "hit": item.hitState,
- "type": "primary",
- "close-transition": ""
- },
- on: {
- "close": function($event) {
- _vm.deleteTag($event, item)
- }
- }
- }, [_c('span', {
- staticClass: "el-select__tags-text"
- }, [_vm._v(_vm._s(item.currentLabel))])])
- })), (_vm.filterable) ? _c('input', {
+ }, [_c('span', {
+ staticClass: "el-radio__inner"
+ }), _c('input', {
directives: [{
name: "model",
rawName: "v-model",
- value: (_vm.query),
- expression: "query"
+ value: (_vm.model),
+ expression: "model"
}],
- ref: "input",
- staticClass: "el-select__input",
- class: ("is-" + _vm.size),
- style: ({
- width: _vm.inputLength + 'px',
- 'max-width': _vm.inputWidth - 42 + 'px'
- }),
+ staticClass: "el-radio__original",
attrs: {
- "type": "text",
- "disabled": _vm.disabled,
- "debounce": _vm.remote ? 300 : 0
+ "type": "radio",
+ "name": _vm.name,
+ "disabled": _vm.isDisabled
},
domProps: {
- "value": (_vm.query)
+ "value": _vm.label,
+ "checked": _vm._q(_vm.model, _vm.label)
},
on: {
"focus": function($event) {
- _vm.visible = true
- },
- "keyup": _vm.managePlaceholder,
- "keydown": [_vm.resetInputState, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
- $event.preventDefault();
- _vm.navigateOptions('next')
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
- $event.preventDefault();
- _vm.navigateOptions('prev')
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
- $event.preventDefault();
- _vm.selectOption($event)
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "esc", 27)) { return null; }
- $event.stopPropagation();
- $event.preventDefault();
- _vm.visible = false
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "delete", [8, 46])) { return null; }
- _vm.deletePrevTag($event)
- }],
- "input": function($event) {
- if ($event.target.composing) { return; }
- _vm.query = $event.target.value
- }
- }
- }) : _vm._e()], 1) : _vm._e(), _c('el-input', {
- ref: "reference",
- attrs: {
- "type": "text",
- "placeholder": _vm.currentPlaceholder,
- "name": _vm.name,
- "size": _vm.size,
- "disabled": _vm.disabled,
- "readonly": !_vm.filterable || _vm.multiple,
- "validate-event": false,
- "icon": _vm.iconClass
- },
- on: {
- "focus": _vm.handleFocus,
- "click": _vm.handleIconClick
- },
- nativeOn: {
- "mousedown": function($event) {
- _vm.handleMouseDown($event)
- },
- "keyup": function($event) {
- _vm.debouncedOnInputChange($event)
- },
- "keydown": [function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
- $event.preventDefault();
- _vm.navigateOptions('next')
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
- $event.preventDefault();
- _vm.navigateOptions('prev')
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
- $event.preventDefault();
- _vm.selectOption($event)
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "esc", 27)) { return null; }
- $event.stopPropagation();
- $event.preventDefault();
- _vm.visible = false
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "tab", 9)) { return null; }
- _vm.visible = false
- }],
- "paste": function($event) {
- _vm.debouncedOnInputChange($event)
+ _vm.focus = true
},
- "mouseenter": function($event) {
- _vm.inputHovering = true
+ "blur": function($event) {
+ _vm.focus = false
},
- "mouseleave": function($event) {
- _vm.inputHovering = false
+ "__c": function($event) {
+ _vm.model = _vm.label
}
- },
- model: {
- value: (_vm.selectedLabel),
- callback: function($$v) {
- _vm.selectedLabel = $$v
- },
- expression: "selectedLabel"
- }
- }), _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"
- }, [_c('el-scrollbar', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.options.length > 0 && !_vm.loading),
- expression: "options.length > 0 && !loading"
- }],
- class: {
- 'is-empty': !_vm.allowCreate && _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.options.length === 0 || !_vm.allowCreate)) ? _c('p', {
- staticClass: "el-select-dropdown__empty"
- }, [_vm._v(_vm._s(_vm.emptyText))]) : _vm._e()], 1)], 1)], 1)
+ })]), _c('span', {
+ staticClass: "el-radio__label"
+ }, [_vm._t("default"), (!_vm.$slots.default) ? [_vm._v(_vm._s(_vm.label))] : _vm._e()], 2)])
},staticRenderFns: []}
/***/ },
-/* 114 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _option = __webpack_require__(105);
-
- var _option2 = _interopRequireDefault(_option);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _option2.default.install = function (Vue) {
- Vue.component(_option2.default.name, _option2.default);
- };
-
- exports.default = _option2.default;
-
-/***/ },
-/* 115 */
+/* 75 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _optionGroup = __webpack_require__(116);
+ var _radioGroup = __webpack_require__(76);
- var _optionGroup2 = _interopRequireDefault(_optionGroup);
+ var _radioGroup2 = _interopRequireDefault(_radioGroup);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _optionGroup2.default.install = function (Vue) {
- Vue.component(_optionGroup2.default.name, _optionGroup2.default);
+ _radioGroup2.default.install = function (Vue) {
+ Vue.component(_radioGroup2.default.name, _radioGroup2.default);
};
- exports.default = _optionGroup2.default;
+ exports.default = _radioGroup2.default;
/***/ },
-/* 116 */
+/* 76 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(117),
+ __webpack_require__(77),
/* template */
- __webpack_require__(118),
+ __webpack_require__(78),
/* styles */
null,
/* scopeId */
@@ -40724,7 +39542,7 @@ module.exports =
/***/ },
-/* 117 */
+/* 77 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
@@ -40738,47 +39556,23 @@ module.exports =
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- mixins: [_emitter2.default],
+ name: 'ElRadioGroup',
- name: 'ElOptionGroup',
+ componentName: 'ElRadioGroup',
- componentName: 'ElOptionGroup',
+ mixins: [_emitter2.default],
props: {
- label: String,
- disabled: {
- type: Boolean,
- default: false
- }
- },
-
- data: function data() {
- return {
- visible: true
- };
+ value: {},
+ size: String,
+ fill: String,
+ textColor: String,
+ disabled: Boolean
},
-
-
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);
+ value: function value(_value) {
+ this.$emit('change', _value);
+ this.dispatch('ElFormItem', 'el.form.change', [this.value]);
}
}
}; //
@@ -40786,63 +39580,47 @@ module.exports =
//
//
//
- //
- //
- //
- //
- //
- //
/***/ },
-/* 118 */
+/* 78 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('ul', {
- staticClass: "el-select-group__wrap"
- }, [_c('li', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.visible),
- expression: "visible"
- }],
- staticClass: "el-select-group__title"
- }, [_vm._v(_vm._s(_vm.label))]), _c('li', [_c('ul', {
- staticClass: "el-select-group"
- }, [_vm._t("default")], 2)])])
+ return _c('div', {
+ staticClass: "el-radio-group"
+ }, [_vm._t("default")], 2)
},staticRenderFns: []}
/***/ },
-/* 119 */
+/* 79 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _button = __webpack_require__(120);
+ var _radioButton = __webpack_require__(80);
- var _button2 = _interopRequireDefault(_button);
+ var _radioButton2 = _interopRequireDefault(_radioButton);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _button2.default.install = function (Vue) {
- Vue.component(_button2.default.name, _button2.default);
+ _radioButton2.default.install = function (Vue) {
+ Vue.component(_radioButton2.default.name, _radioButton2.default);
};
- exports.default = _button2.default;
+ exports.default = _radioButton2.default;
/***/ },
-/* 120 */
+/* 80 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(121),
+ __webpack_require__(81),
/* template */
- __webpack_require__(122),
+ __webpack_require__(82),
/* styles */
null,
/* scopeId */
@@ -40855,7 +39633,7 @@ module.exports =
/***/ },
-/* 121 */
+/* 81 */
/***/ function(module, exports) {
'use strict';
@@ -40881,112 +39659,126 @@ module.exports =
//
//
//
+ //
+ //
exports.default = {
- name: 'ElButton',
+ name: 'ElRadioButton',
props: {
- type: {
- type: String,
- default: 'default'
- },
- size: String,
- icon: {
- type: String,
- default: ''
- },
- nativeType: {
- type: String,
- default: 'button'
- },
- loading: Boolean,
+ label: {},
disabled: Boolean,
- plain: Boolean,
- autofocus: Boolean
+ name: String
},
-
- methods: {
- handleClick: function handleClick(evt) {
- this.$emit('click', evt);
+ computed: {
+ value: {
+ get: function get() {
+ return this._radioGroup.value;
+ },
+ set: function set(value) {
+ this._radioGroup.$emit('input', value);
+ }
},
- handleInnerClick: function handleInnerClick(evt) {
- if (this.disabled) {
- evt.stopPropagation();
+ _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 || ''
+ };
+ },
+ size: function size() {
+ return this._radioGroup.size;
+ },
+ isDisabled: function isDisabled() {
+ return this.disabled || this._radioGroup.disabled;
}
}
};
/***/ },
-/* 122 */
+/* 82 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('button', {
- staticClass: "el-button",
+ return _c('label', {
+ staticClass: "el-radio-button",
class: [
- _vm.type ? 'el-button--' + _vm.type : '',
- _vm.size ? 'el-button--' + _vm.size : '', {
- 'is-disabled': _vm.disabled,
- 'is-loading': _vm.loading,
- 'is-plain': _vm.plain
+ _vm.size ? 'el-radio-button--' + _vm.size : '', {
+ 'is-active': _vm.value === _vm.label
+ }, {
+ 'is-disabled': _vm.isDisabled
}
- ],
+ ]
+ }, [_c('input', {
+ directives: [{
+ name: "model",
+ rawName: "v-model",
+ value: (_vm.value),
+ expression: "value"
+ }],
+ staticClass: "el-radio-button__orig-radio",
attrs: {
- "disabled": _vm.disabled,
- "autofocus": _vm.autofocus,
- "type": _vm.nativeType
+ "type": "radio",
+ "name": _vm.name,
+ "disabled": _vm.isDisabled
+ },
+ domProps: {
+ "value": _vm.label,
+ "checked": _vm._q(_vm.value, _vm.label)
},
on: {
- "click": _vm.handleClick
- }
- }, [(_vm.loading) ? _c('i', {
- staticClass: "el-icon-loading",
- on: {
- "click": _vm.handleInnerClick
- }
- }) : _vm._e(), (_vm.icon && !_vm.loading) ? _c('i', {
- class: 'el-icon-' + _vm.icon,
- on: {
- "click": _vm.handleInnerClick
- }
- }) : _vm._e(), (_vm.$slots.default) ? _c('span', {
- on: {
- "click": _vm.handleInnerClick
+ "__c": function($event) {
+ _vm.value = _vm.label
+ }
}
- }, [_vm._t("default")], 2) : _vm._e()])
+ }), _c('span', {
+ staticClass: "el-radio-button__inner",
+ style: (_vm.value === _vm.label ? _vm.activeStyle : null)
+ }, [_vm._t("default"), (!_vm.$slots.default) ? [_vm._v(_vm._s(_vm.label))] : _vm._e()], 2)])
},staticRenderFns: []}
/***/ },
-/* 123 */
+/* 83 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _buttonGroup = __webpack_require__(124);
+ var _checkbox = __webpack_require__(84);
- var _buttonGroup2 = _interopRequireDefault(_buttonGroup);
+ var _checkbox2 = _interopRequireDefault(_checkbox);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _buttonGroup2.default.install = function (Vue) {
- Vue.component(_buttonGroup2.default.name, _buttonGroup2.default);
+ _checkbox2.default.install = function (Vue) {
+ Vue.component(_checkbox2.default.name, _checkbox2.default);
};
- exports.default = _buttonGroup2.default;
+ exports.default = _checkbox2.default;
/***/ },
-/* 124 */
+/* 84 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(125),
+ __webpack_require__(85),
/* template */
- __webpack_require__(126),
+ __webpack_require__(86),
/* styles */
null,
/* scopeId */
@@ -40999,230 +39791,115 @@ module.exports =
/***/ },
-/* 125 */
-/***/ function(module, exports) {
-
- 'use strict';
-
- exports.__esModule = true;
- //
- //
- //
- //
- //
-
- /**
- * button
- * @module components/basic/menu
- * @desc 用于按钮组
- * @param {string} label - 名称
- */
- exports.default = {
- name: 'ElButtonGroup'
- };
-
-/***/ },
-/* 126 */
-/***/ function(module, exports) {
-
- module.exports={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)
- },staticRenderFns: []}
-
-/***/ },
-/* 127 */
+/* 85 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _table = __webpack_require__(128);
+ var _emitter = __webpack_require__(15);
- var _table2 = _interopRequireDefault(_table);
+ var _emitter2 = _interopRequireDefault(_emitter);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- /* istanbul ignore next */
- _table2.default.install = function (Vue) {
- Vue.component(_table2.default.name, _table2.default);
- };
-
- exports.default = _table2.default;
-
-/***/ },
-/* 128 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(129),
- /* template */
- __webpack_require__(146),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
-
-/***/ },
-/* 129 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _checkbox = __webpack_require__(130);
-
- var _checkbox2 = _interopRequireDefault(_checkbox);
-
- var _throttle = __webpack_require__(131);
-
- var _throttle2 = _interopRequireDefault(_throttle);
-
- var _debounce = __webpack_require__(69);
-
- var _debounce2 = _interopRequireDefault(_debounce);
-
- var _resizeEvent = __webpack_require__(110);
-
- var _locale = __webpack_require__(10);
-
- var _locale2 = _interopRequireDefault(_locale);
-
- var _tableStore = __webpack_require__(132);
+ exports.default = {
+ name: 'ElCheckbox',
- var _tableStore2 = _interopRequireDefault(_tableStore);
+ mixins: [_emitter2.default],
- var _tableLayout = __webpack_require__(135);
+ componentName: 'ElCheckbox',
- var _tableLayout2 = _interopRequireDefault(_tableLayout);
+ data: function data() {
+ return {
+ selfModel: false,
+ focus: false
+ };
+ },
- var _tableBody = __webpack_require__(137);
- var _tableBody2 = _interopRequireDefault(_tableBody);
+ computed: {
+ model: {
+ get: function get() {
+ return this.isGroup ? this.store : this.value !== undefined ? this.value : this.selfModel;
+ },
+ set: function set(val) {
+ if (this.isGroup) {
+ var isLimitExceeded = false;
+ this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (isLimitExceeded = true);
- var _tableHeader = __webpack_require__(139);
+ this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (isLimitExceeded = true);
- var _tableHeader2 = _interopRequireDefault(_tableHeader);
+ isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]);
+ } else {
+ this.$emit('input', val);
+ this.selfModel = val;
+ }
+ }
+ },
- var _tableFooter = __webpack_require__(145);
+ 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;
+ }
+ },
- var _tableFooter2 = _interopRequireDefault(_tableFooter);
+ props: {
+ value: {},
+ label: {},
+ indeterminate: Boolean,
+ disabled: Boolean,
+ checked: Boolean,
+ name: String,
+ trueLabel: [String, Number],
+ falseLabel: [String, Number]
+ },
- var _util = __webpack_require__(134);
+ 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;
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ this.$emit('change', ev);
+ if (this.isGroup) {
+ this.$nextTick(function (_) {
+ _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]);
+ });
+ }
+ }
+ },
- var tableIdSeed = 1; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ created: function created() {
+ this.checked && this.addToStore();
+ }
+ }; //
//
//
//
@@ -41264,2024 +39941,2202 @@ module.exports =
//
//
- exports.default = {
- name: 'ElTable',
-
- mixins: [_locale2.default],
+/***/ },
+/* 86 */
+/***/ function(module, exports) {
- props: {
- data: {
- type: Array,
- default: function _default() {
- return [];
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('label', {
+ staticClass: "el-checkbox"
+ }, [_c('span', {
+ staticClass: "el-checkbox__input",
+ class: {
+ 'is-disabled': _vm.disabled,
+ 'is-checked': _vm.isChecked,
+ 'is-indeterminate': _vm.indeterminate,
+ 'is-focus': _vm.focus
+ }
+ }, [_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",
+ "name": _vm.name,
+ "disabled": _vm.disabled,
+ "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": _vm.handleChange,
+ "focus": function($event) {
+ _vm.focus = true
+ },
+ "blur": function($event) {
+ _vm.focus = false
+ },
+ "__c": 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 ($$c) {
+ $$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
+ }
}
+ }
+ }) : _c('input', {
+ directives: [{
+ name: "model",
+ rawName: "v-model",
+ value: (_vm.model),
+ expression: "model"
+ }],
+ staticClass: "el-checkbox__original",
+ attrs: {
+ "type": "checkbox",
+ "disabled": _vm.disabled,
+ "name": _vm.name
},
-
- width: [String, Number],
-
- height: [String, Number],
-
- maxHeight: [String, Number],
-
- fit: {
- type: Boolean,
- default: true
+ domProps: {
+ "value": _vm.label,
+ "checked": Array.isArray(_vm.model) ? _vm._i(_vm.model, _vm.label) > -1 : (_vm.model)
},
+ on: {
+ "change": _vm.handleChange,
+ "focus": function($event) {
+ _vm.focus = true
+ },
+ "blur": function($event) {
+ _vm.focus = false
+ },
+ "__c": 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 ($$c) {
+ $$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.$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()])
+ },staticRenderFns: []}
- stripe: Boolean,
+/***/ },
+/* 87 */
+/***/ function(module, exports, __webpack_require__) {
- border: Boolean,
+ 'use strict';
- rowKey: [String, Function],
+ exports.__esModule = true;
- context: {},
+ var _checkboxButton = __webpack_require__(88);
- showHeader: {
- type: Boolean,
- default: true
- },
+ var _checkboxButton2 = _interopRequireDefault(_checkboxButton);
- showSummary: Boolean,
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- sumText: String,
+ /* istanbul ignore next */
+ _checkboxButton2.default.install = function (Vue) {
+ Vue.component(_checkboxButton2.default.name, _checkboxButton2.default);
+ };
- summaryMethod: Function,
+ exports.default = _checkboxButton2.default;
- rowClassName: [String, Function],
+/***/ },
+/* 88 */
+/***/ function(module, exports, __webpack_require__) {
- rowStyle: [Object, Function],
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(89),
+ /* template */
+ __webpack_require__(90),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- highlightCurrentRow: Boolean,
+ module.exports = Component.exports
- currentRowKey: [String, Number],
- emptyText: String,
+/***/ },
+/* 89 */
+/***/ function(module, exports, __webpack_require__) {
- expandRowKeys: Array,
+ 'use strict';
- defaultExpandAll: Boolean,
+ exports.__esModule = true;
- defaultSort: Object,
+ var _emitter = __webpack_require__(15);
- tooltipEffect: String
- },
+ var _emitter2 = _interopRequireDefault(_emitter);
- components: {
- TableHeader: _tableHeader2.default,
- TableFooter: _tableFooter2.default,
- TableBody: _tableBody2.default,
- ElCheckbox: _checkbox2.default
- },
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- methods: {
- setCurrentRow: function setCurrentRow(row) {
- this.store.commit('setCurrentRow', row);
- },
- toggleRowSelection: function toggleRowSelection(row, selected) {
- this.store.toggleRowSelection(row, selected);
- this.store.updateAllSelected();
- },
- clearSelection: function clearSelection() {
- this.store.clearSelection();
- },
- handleMouseLeave: function handleMouseLeave() {
- this.store.commit('setHoverRow', null);
- if (this.hoverState) this.hoverState = null;
- },
- updateScrollY: function updateScrollY() {
- this.layout.updateScrollY();
- },
- bindEvents: function bindEvents() {
- var _this = this;
+ exports.default = {
+ name: 'ElCheckboxButton',
- var _$refs = this.$refs,
- headerWrapper = _$refs.headerWrapper,
- footerWrapper = _$refs.footerWrapper;
+ mixins: [_emitter2.default],
- var refs = this.$refs;
- this.bodyWrapper.addEventListener('scroll', function () {
- if (headerWrapper) headerWrapper.scrollLeft = this.scrollLeft;
- if (footerWrapper) footerWrapper.scrollLeft = this.scrollLeft;
- if (refs.fixedBodyWrapper) refs.fixedBodyWrapper.scrollTop = this.scrollTop;
- if (refs.rightFixedBodyWrapper) refs.rightFixedBodyWrapper.scrollTop = this.scrollTop;
- });
+ data: function data() {
+ return {
+ selfModel: false,
+ focus: false
+ };
+ },
- var scrollBodyWrapper = function scrollBodyWrapper(event) {
- var deltaX = event.deltaX,
- deltaY = event.deltaY;
+ 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) {
+ var isLimitExceeded = false;
+ this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (isLimitExceeded = true);
- if (Math.abs(deltaX) < Math.abs(deltaY)) return;
+ this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (isLimitExceeded = true);
- if (deltaX > 0) {
- _this.bodyWrapper.scrollLeft += 10;
- } else if (deltaX < 0) {
- _this.bodyWrapper.scrollLeft -= 10;
+ isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]);
+ } else if (this.value !== undefined) {
+ this.$emit('input', val);
+ } else {
+ this.selfModel = val;
}
- };
- if (headerWrapper) {
- (0, _util.mousewheel)(headerWrapper, (0, _throttle2.default)(16, scrollBodyWrapper));
- }
- if (footerWrapper) {
- (0, _util.mousewheel)(footerWrapper, (0, _throttle2.default)(16, scrollBodyWrapper));
}
+ },
- if (this.fit) {
- this.windowResizeListener = (0, _throttle2.default)(50, function () {
- if (_this.$ready) _this.doLayout();
- });
- (0, _resizeEvent.addResizeListener)(this.$el, this.windowResizeListener);
+ 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;
}
},
- doLayout: function doLayout() {
- var _this2 = this;
-
- this.store.updateColumns();
- this.layout.update();
- this.updateScrollY();
- this.$nextTick(function () {
- if (_this2.height) {
- _this2.layout.setHeight(_this2.height);
- } else if (_this2.maxHeight) {
- _this2.layout.setMaxHeight(_this2.maxHeight);
- } else if (_this2.shouldUpdateHeight) {
- _this2.layout.updateHeight();
- }
- if (_this2.$el) {
- _this2.isHidden = _this2.$el.clientWidth === 0;
+ _checkboxGroup: function _checkboxGroup() {
+ var parent = this.$parent;
+ while (parent) {
+ if (parent.$options.componentName !== 'ElCheckboxGroup') {
+ parent = parent.$parent;
+ } else {
+ return parent;
}
- });
- }
- },
-
- created: function created() {
- var _this3 = this;
-
- this.tableId = 'el-table_' + tableIdSeed + '_';
- this.debouncedLayout = (0, _debounce2.default)(50, function () {
- return _this3.doLayout();
- });
- },
-
-
- computed: {
- bodyWrapper: function bodyWrapper() {
- return this.$refs.bodyWrapper;
- },
- shouldUpdateHeight: function shouldUpdateHeight() {
- return typeof this.height === 'number' || this.fixedColumns.length > 0 || this.rightFixedColumns.length > 0;
- },
- selection: function selection() {
- return this.store.states.selection;
- },
- columns: function columns() {
- return this.store.states.columns;
- },
- tableData: function tableData() {
- return this.store.states.data;
- },
- fixedColumns: function fixedColumns() {
- return this.store.states.fixedColumns;
- },
- rightFixedColumns: function rightFixedColumns() {
- return this.store.states.rightFixedColumns;
- },
- bodyHeight: function bodyHeight() {
- var style = {};
-
- if (this.height) {
- style = {
- height: this.layout.bodyHeight ? this.layout.bodyHeight + 'px' : ''
- };
- } else if (this.maxHeight) {
- style = {
- 'max-height': (this.showHeader ? this.maxHeight - this.layout.headerHeight - this.layout.footerHeight : this.maxHeight - this.layout.footerHeight) + 'px'
- };
}
-
- return style;
+ return false;
},
- bodyWidth: function bodyWidth() {
- var _layout = this.layout,
- bodyWidth = _layout.bodyWidth,
- scrollY = _layout.scrollY,
- gutterWidth = _layout.gutterWidth;
-
- return bodyWidth ? bodyWidth - (scrollY ? gutterWidth : 0) + 'px' : '';
+ store: function store() {
+ return this._checkboxGroup ? this._checkboxGroup.value : this.value;
},
- fixedBodyHeight: function fixedBodyHeight() {
- var style = {};
-
- if (this.height) {
- style = {
- height: this.layout.fixedBodyHeight ? this.layout.fixedBodyHeight + 'px' : ''
- };
- } else if (this.maxHeight) {
- var maxHeight = this.layout.scrollX ? this.maxHeight - this.layout.gutterWidth : this.maxHeight;
-
- if (this.showHeader) {
- maxHeight -= this.layout.headerHeight;
- }
-
- style = {
- 'max-height': maxHeight + 'px'
- };
- }
+ 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
- return style;
+ };
},
- fixedHeight: function fixedHeight() {
- var style = {};
-
- if (this.maxHeight) {
- style = {
- bottom: this.layout.scrollX && this.data.length ? this.layout.gutterWidth + 'px' : ''
- };
- } else {
- style = {
- height: this.layout.viewportHeight ? this.layout.viewportHeight + 'px' : ''
- };
- }
-
- return style;
+ size: function size() {
+ return this._checkboxGroup.size;
}
},
-
- watch: {
- height: function height(value) {
- this.layout.setHeight(value);
- },
- currentRowKey: function currentRowKey(newVal) {
- this.store.setCurrentRowKey(newVal);
- },
-
-
- data: {
- immediate: true,
- handler: function handler(val) {
- this.store.commit('setData', val);
- if (this.$ready) this.doLayout();
+ 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;
- expandRowKeys: function expandRowKeys(newVal) {
- this.store.setExpandRowKeys(newVal);
- }
- },
-
- destroyed: function destroyed() {
- if (this.windowResizeListener) (0, _resizeEvent.removeResizeListener)(this.$el, this.windowResizeListener);
- },
- mounted: function mounted() {
- var _this4 = this;
-
- this.bindEvents();
- this.doLayout();
-
- // init filters
- this.store.states.columns.forEach(function (column) {
- if (column.filteredValue && column.filteredValue.length) {
- _this4.store.commit('filterChange', {
- column: column,
- values: column.filteredValue,
- silent: true
+ this.$emit('change', ev);
+ if (this._checkboxGroup) {
+ this.$nextTick(function (_) {
+ _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]);
});
}
- });
-
- this.$ready = true;
+ }
},
- data: function data() {
- var store = new _tableStore2.default(this, {
- rowKey: this.rowKey,
- defaultExpandAll: this.defaultExpandAll
- });
- var layout = new _tableLayout2.default({
- store: store,
- table: this,
- fit: this.fit,
- showHeader: this.showHeader
- });
- return {
- store: store,
- layout: layout,
- isHidden: false,
- renderExpanded: null,
- resizeProxyVisible: false
- };
+
+ created: function created() {
+ this.checked && this.addToStore();
}
- };
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
/***/ },
-/* 130 */
+/* 90 */
/***/ function(module, exports) {
- module.exports = __webpack_require__(51);
-
-/***/ },
-/* 131 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(25);
+ module.exports={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.disabled
+ }, {
+ 'is-checked': _vm.isChecked
+ }, {
+ 'is-focus': _vm.focus
+ } ]
+ }, [(_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.disabled,
+ "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": _vm.handleChange,
+ "focus": function($event) {
+ _vm.focus = true
+ },
+ "blur": function($event) {
+ _vm.focus = false
+ },
+ "__c": 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 ($$c) {
+ $$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
+ }
+ }
+ }
+ }) : _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.disabled
+ },
+ domProps: {
+ "value": _vm.label,
+ "checked": Array.isArray(_vm.model) ? _vm._i(_vm.model, _vm.label) > -1 : (_vm.model)
+ },
+ on: {
+ "change": _vm.handleChange,
+ "focus": function($event) {
+ _vm.focus = true
+ },
+ "blur": function($event) {
+ _vm.focus = false
+ },
+ "__c": 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 ($$c) {
+ $$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.$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()])
+ },staticRenderFns: []}
/***/ },
-/* 132 */
+/* 91 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _vue = __webpack_require__(133);
-
- var _vue2 = _interopRequireDefault(_vue);
-
- var _debounce = __webpack_require__(69);
-
- var _debounce2 = _interopRequireDefault(_debounce);
+ var _checkboxGroup = __webpack_require__(92);
- var _util = __webpack_require__(134);
+ var _checkboxGroup2 = _interopRequireDefault(_checkboxGroup);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var sortData = function sortData(data, states) {
- var sortingColumn = states.sortingColumn;
- if (!sortingColumn || typeof sortingColumn.sortable === 'string') {
- return data;
- }
- return (0, _util.orderBy)(data, states.sortProp, states.sortOrder, sortingColumn.sortMethod);
+ /* istanbul ignore next */
+ _checkboxGroup2.default.install = function (Vue) {
+ Vue.component(_checkboxGroup2.default.name, _checkboxGroup2.default);
};
- var getKeysMap = function getKeysMap(array, rowKey) {
- var arrayMap = {};
- (array || []).forEach(function (row, index) {
- arrayMap[(0, _util.getRowIdentity)(row, rowKey)] = { row: row, index: index };
- });
- return arrayMap;
- };
+ exports.default = _checkboxGroup2.default;
- var toggleRowSelection = function toggleRowSelection(states, row, selected) {
- var changed = false;
- var selection = states.selection;
- var index = selection.indexOf(row);
- if (typeof selected === 'undefined') {
- if (index === -1) {
- selection.push(row);
- changed = true;
- } else {
- selection.splice(index, 1);
- changed = true;
- }
- } else {
- if (selected && index === -1) {
- selection.push(row);
- changed = true;
- } else if (!selected && index > -1) {
- selection.splice(index, 1);
- changed = true;
- }
- }
+/***/ },
+/* 92 */
+/***/ function(module, exports, __webpack_require__) {
- return changed;
- };
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(93),
+ /* template */
+ __webpack_require__(94),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- var TableStore = function TableStore(table) {
- var initialState = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ module.exports = Component.exports
- if (!table) {
- throw new Error('Table is required.');
- }
- this.table = table;
- this.states = {
- rowKey: null,
- _columns: [],
- originColumns: [],
- columns: [],
- fixedColumns: [],
- rightFixedColumns: [],
- isComplex: false,
- _data: null,
- filteredData: null,
- data: null,
- sortingColumn: null,
- sortProp: null,
- sortOrder: null,
- isAllSelected: false,
- selection: [],
- reserveSelection: false,
- selectable: null,
- currentRow: null,
- hoverRow: null,
- filters: {},
- expandRows: [],
- defaultExpandAll: false
- };
+/***/ },
+/* 93 */
+/***/ function(module, exports, __webpack_require__) {
- for (var prop in initialState) {
- if (initialState.hasOwnProperty(prop) && this.states.hasOwnProperty(prop)) {
- this.states[prop] = initialState[prop];
- }
- }
- };
+ 'use strict';
- TableStore.prototype.mutations = {
- setData: function setData(states, data) {
- var _this = this;
+ exports.__esModule = true;
- var dataInstanceChanged = states._data !== data;
- states._data = data;
- states.data = sortData(data || [], states);
+ var _emitter = __webpack_require__(15);
- // states.data.forEach((item) => {
- // if (!item.$extra) {
- // Object.defineProperty(item, '$extra', {
- // value: {},
- // enumerable: false
- // });
- // }
- // });
+ var _emitter2 = _interopRequireDefault(_emitter);
- this.updateCurrentRow();
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- if (!states.reserveSelection) {
- if (dataInstanceChanged) {
- this.clearSelection();
- } else {
- this.cleanSelection();
- }
- this.updateAllSelected();
- } else {
- (function () {
- var rowKey = states.rowKey;
- if (rowKey) {
- (function () {
- var selection = states.selection;
- var selectedMap = getKeysMap(selection, rowKey);
+ exports.default = {
+ name: 'ElCheckboxGroup',
- states.data.forEach(function (row) {
- var rowId = (0, _util.getRowIdentity)(row, rowKey);
- var rowInfo = selectedMap[rowId];
- if (rowInfo) {
- selection[rowInfo.index] = row;
- }
- });
+ componentName: 'ElCheckboxGroup',
- _this.updateAllSelected();
- })();
- } else {
- console.warn('WARN: rowKey is required when reserve-selection is enabled.');
- }
- })();
- }
+ mixins: [_emitter2.default],
- var defaultExpandAll = states.defaultExpandAll;
- if (defaultExpandAll) {
- this.states.expandRows = (states.data || []).slice(0);
+ props: {
+ value: {},
+ min: Number,
+ max: Number,
+ size: String,
+ fill: String,
+ textColor: String
+ },
+
+ watch: {
+ value: function value(_value) {
+ this.dispatch('ElFormItem', 'el.form.change', [_value]);
}
+ }
+ };
- _vue2.default.nextTick(function () {
- return _this.table.updateScrollY();
- });
- },
- changeSortCondition: function changeSortCondition(states) {
- var _this2 = this;
+/***/ },
+/* 94 */
+/***/ function(module, exports) {
- states.data = sortData(states.filteredData || states._data || [], states);
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-checkbox-group"
+ }, [_vm._t("default")], 2)
+ },staticRenderFns: []}
- this.table.$emit('sort-change', {
- column: this.states.sortingColumn,
- prop: this.states.sortProp,
- order: this.states.sortOrder
- });
+/***/ },
+/* 95 */
+/***/ function(module, exports, __webpack_require__) {
- _vue2.default.nextTick(function () {
- return _this2.table.updateScrollY();
- });
- },
- filterChange: function filterChange(states, options) {
- var _this3 = this;
+ 'use strict';
- var column = options.column,
- values = options.values,
- silent = options.silent;
+ exports.__esModule = true;
- if (values && !Array.isArray(values)) {
- values = [values];
- }
+ var _component = __webpack_require__(96);
- var prop = column.property;
- var filters = {};
+ var _component2 = _interopRequireDefault(_component);
- if (prop) {
- states.filters[column.id] = values;
- filters[column.columnKey || column.id] = values;
- }
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var data = states._data;
+ /* istanbul ignore next */
+ _component2.default.install = function (Vue) {
+ Vue.component(_component2.default.name, _component2.default);
+ };
- Object.keys(states.filters).forEach(function (columnId) {
- var values = states.filters[columnId];
- if (!values || values.length === 0) return;
- var column = (0, _util.getColumnById)(_this3.states, columnId);
- if (column && column.filterMethod) {
- data = data.filter(function (row) {
- return values.some(function (value) {
- return column.filterMethod.call(null, value, row);
- });
- });
- }
- });
+ exports.default = _component2.default;
- states.filteredData = data;
- states.data = sortData(data, states);
+/***/ },
+/* 96 */
+/***/ function(module, exports, __webpack_require__) {
- if (!silent) {
- this.table.$emit('filter-change', filters);
- }
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(97),
+ /* template */
+ __webpack_require__(98),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- _vue2.default.nextTick(function () {
- return _this3.table.updateScrollY();
- });
- },
- insertColumn: function insertColumn(states, column, index, parent) {
- var array = states._columns;
- if (parent) {
- array = parent.children;
- if (!array) array = parent.children = [];
- }
+ module.exports = Component.exports
- 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;
- }
+/***/ },
+/* 97 */
+/***/ function(module, exports) {
- this.updateColumns(); // hack for dynamics insert column
- this.scheduleLayout();
- },
- removeColumn: function removeColumn(states, column) {
- var _columns = states._columns;
- if (_columns) {
- _columns.splice(_columns.indexOf(column), 1);
- }
+ 'use strict';
- this.updateColumns(); // hack for dynamics remove column
- this.scheduleLayout();
- },
- setHoverRow: function setHoverRow(states, row) {
- states.hoverRow = row;
- },
- setCurrentRow: function setCurrentRow(states, row) {
- var oldCurrentRow = states.currentRow;
- states.currentRow = row;
+ exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- if (oldCurrentRow !== row) {
- this.table.$emit('current-change', row, oldCurrentRow);
+ exports.default = {
+ name: 'ElSwitch',
+ props: {
+ value: {
+ type: [Boolean, String, Number],
+ default: false
+ },
+ disabled: {
+ type: Boolean,
+ default: false
+ },
+ width: {
+ type: Number,
+ default: 0
+ },
+ onIconClass: {
+ type: String,
+ default: ''
+ },
+ offIconClass: {
+ type: String,
+ default: ''
+ },
+ onText: {
+ type: String,
+ default: 'ON'
+ },
+ offText: {
+ type: String,
+ default: 'OFF'
+ },
+ onColor: {
+ type: String,
+ default: ''
+ },
+ offColor: {
+ type: String,
+ default: ''
+ },
+ onValue: {
+ type: [Boolean, String, Number],
+ default: true
+ },
+ offValue: {
+ type: [Boolean, String, Number],
+ default: false
+ },
+ name: {
+ type: String,
+ default: ''
}
},
- rowSelectedChanged: function rowSelectedChanged(states, row) {
- var changed = toggleRowSelection(states, row);
- var selection = states.selection;
-
- if (changed) {
- var table = this.table;
- table.$emit('selection-change', selection);
- table.$emit('select', selection, row);
+ data: function data() {
+ return {
+ coreWidth: this.width
+ };
+ },
+ created: function created() {
+ if (!~[this.onValue, this.offValue].indexOf(this.value)) {
+ this.$emit('input', this.offValue);
}
+ },
- this.updateAllSelected();
+ computed: {
+ checked: function checked() {
+ return this.value === this.onValue;
+ },
+ hasText: function hasText() {
+ /* istanbul ignore next */
+ return this.onText || this.offText;
+ },
+ transform: function transform() {
+ return this.checked ? 'translate(' + (this.coreWidth - 20) + 'px, 2px)' : 'translate(2px, 2px)';
+ }
},
-
-
- toggleRowExpanded: function toggleRowExpanded(states, row, expanded) {
- var expandRows = states.expandRows;
- if (typeof expanded !== 'undefined') {
- var index = expandRows.indexOf(row);
- if (expanded) {
- if (index === -1) expandRows.push(row);
- } else {
- if (index !== -1) expandRows.splice(index, 1);
- }
- } else {
- var _index = expandRows.indexOf(row);
- if (_index === -1) {
- expandRows.push(row);
- } else {
- expandRows.splice(_index, 1);
+ watch: {
+ checked: function checked() {
+ this.$refs.input.checked = this.checked;
+ if (this.onColor || this.offColor) {
+ this.setBackgroundColor();
}
}
- this.table.$emit('expand', row, expandRows.indexOf(row) !== -1);
},
+ methods: {
+ handleChange: function handleChange(event) {
+ var _this = this;
- toggleAllSelection: (0, _debounce2.default)(10, function (states) {
- var data = states.data || [];
- var value = !states.isAllSelected;
- var selection = this.states.selection;
- var selectionChanged = false;
-
- data.forEach(function (item, index) {
- if (states.selectable) {
- if (states.selectable.call(null, item, index) && toggleRowSelection(states, item, value)) {
- selectionChanged = true;
- }
- } else {
- if (toggleRowSelection(states, item, value)) {
- selectionChanged = true;
- }
- }
- });
-
- var table = this.table;
- if (selectionChanged) {
- table.$emit('selection-change', selection);
+ this.$emit('input', !this.checked ? this.onValue : this.offValue);
+ this.$emit('change', !this.checked ? this.onValue : this.offValue);
+ 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.onColor : this.offColor;
+ this.$refs.core.style.borderColor = newColor;
+ this.$refs.core.style.backgroundColor = newColor;
}
- table.$emit('select-all', selection);
- states.isAllSelected = value;
- })
+ },
+ mounted: function mounted() {
+ /* istanbul ignore if */
+ if (this.width === 0) {
+ this.coreWidth = this.hasText ? 58 : 46;
+ }
+ if (this.onColor || this.offColor) {
+ this.setBackgroundColor();
+ }
+ this.$refs.input.checked = this.checked;
+ }
};
- 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);
+/***/ },
+/* 98 */
+/***/ function(module, exports) {
+
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('label', {
+ staticClass: "el-switch",
+ class: {
+ 'is-disabled': _vm.disabled, 'el-switch--wide': _vm.hasText, 'is-checked': _vm.checked
}
- });
- return result;
- };
+ }, [_c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.disabled),
+ expression: "disabled"
+ }],
+ staticClass: "el-switch__mask"
+ }), _c('input', {
+ ref: "input",
+ staticClass: "el-switch__input",
+ attrs: {
+ "type": "checkbox",
+ "name": _vm.name,
+ "true-value": _vm.onValue,
+ "false-value": _vm.offValue,
+ "disabled": _vm.disabled
+ },
+ on: {
+ "change": _vm.handleChange
+ }
+ }), _c('span', {
+ ref: "core",
+ staticClass: "el-switch__core",
+ style: ({
+ 'width': _vm.coreWidth + 'px'
+ })
+ }, [_c('span', {
+ staticClass: "el-switch__button",
+ style: ({
+ transform: _vm.transform
+ })
+ })]), _c('transition', {
+ attrs: {
+ "name": "label-fade"
+ }
+ }, [_c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.checked),
+ expression: "checked"
+ }],
+ staticClass: "el-switch__label el-switch__label--left",
+ style: ({
+ 'width': _vm.coreWidth + 'px'
+ })
+ }, [(_vm.onIconClass) ? _c('i', {
+ class: [_vm.onIconClass]
+ }) : _vm._e(), (!_vm.onIconClass && _vm.onText) ? _c('span', [_vm._v(_vm._s(_vm.onText))]) : _vm._e()])]), _c('transition', {
+ attrs: {
+ "name": "label-fade"
+ }
+ }, [_c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (!_vm.checked),
+ expression: "!checked"
+ }],
+ staticClass: "el-switch__label el-switch__label--right",
+ style: ({
+ 'width': _vm.coreWidth + 'px'
+ })
+ }, [(_vm.offIconClass) ? _c('i', {
+ class: [_vm.offIconClass]
+ }) : _vm._e(), (!_vm.offIconClass && _vm.offText) ? _c('span', [_vm._v(_vm._s(_vm.offText))]) : _vm._e()])])], 1)
+ },staticRenderFns: []}
- TableStore.prototype.updateColumns = function () {
- 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';
- });
+/***/ },
+/* 99 */
+/***/ function(module, exports, __webpack_require__) {
- if (states.fixedColumns.length > 0 && _columns[0] && _columns[0].type === 'selection' && !_columns[0].fixed) {
- _columns[0].fixed = true;
- states.fixedColumns.unshift(_columns[0]);
- }
- states.originColumns = [].concat(states.fixedColumns).concat(_columns.filter(function (column) {
- return !column.fixed;
- })).concat(states.rightFixedColumns);
- states.columns = doFlattenColumns(states.originColumns);
- states.isComplex = states.fixedColumns.length > 0 || states.rightFixedColumns.length > 0;
- };
+ 'use strict';
- TableStore.prototype.isSelected = function (row) {
- return (this.states.selection || []).indexOf(row) > -1;
- };
+ exports.__esModule = true;
- TableStore.prototype.clearSelection = function () {
- var states = this.states;
- states.isAllSelected = false;
- var oldSelection = states.selection;
- states.selection = [];
- if (oldSelection.length > 0) {
- this.table.$emit('selection-change', states.selection);
- }
- };
+ var _select = __webpack_require__(100);
- TableStore.prototype.setExpandRowKeys = function (rowKeys) {
- var expandRows = [];
- var data = this.states.data;
- var rowKey = this.states.rowKey;
- if (!rowKey) throw new Error('[Table] prop row-key should not be empty.');
- var keysMap = getKeysMap(data, rowKey);
- rowKeys.forEach(function (key) {
- var info = keysMap[key];
- if (info) {
- expandRows.push(info.row);
- }
- });
+ var _select2 = _interopRequireDefault(_select);
- this.states.expandRows = expandRows;
- };
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- TableStore.prototype.toggleRowSelection = function (row, selected) {
- var changed = toggleRowSelection(this.states, row, selected);
- if (changed) {
- this.table.$emit('selection-change', this.states.selection);
- }
+ /* istanbul ignore next */
+ _select2.default.install = function (Vue) {
+ Vue.component(_select2.default.name, _select2.default);
};
- TableStore.prototype.cleanSelection = function () {
- var selection = this.states.selection || [];
- var data = this.states.data;
- var rowKey = this.states.rowKey;
- 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;
- });
- }
+ exports.default = _select2.default;
- deleted.forEach(function (deletedItem) {
- selection.splice(selection.indexOf(deletedItem), 1);
- });
+/***/ },
+/* 100 */
+/***/ function(module, exports, __webpack_require__) {
- if (deleted.length) {
- this.table.$emit('selection-change', selection);
- }
- };
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(101),
+ /* template */
+ __webpack_require__(113),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- TableStore.prototype.updateAllSelected = function () {
- var states = this.states;
- var selection = states.selection,
- rowKey = states.rowKey,
- selectable = states.selectable,
- data = states.data;
+ module.exports = Component.exports
- if (!data || data.length === 0) {
- states.isAllSelected = false;
- return;
- }
- var selectedMap = void 0;
- if (rowKey) {
- selectedMap = getKeysMap(states.selection, rowKey);
- }
+/***/ },
+/* 101 */
+/***/ function(module, exports, __webpack_require__) {
- var isSelected = function isSelected(row) {
- if (selectedMap) {
- return !!selectedMap[(0, _util.getRowIdentity)(row, rowKey)];
- } else {
- return selection.indexOf(row) !== -1;
- }
- };
+ 'use strict';
- var isAllSelected = true;
- var selectedCount = 0;
- for (var i = 0, j = data.length; i < j; i++) {
- var item = data[i];
- if (selectable) {
- var isRowSelectable = selectable.call(null, item, i);
- if (isRowSelectable) {
- if (!isSelected(item)) {
- isAllSelected = false;
- break;
- } else {
- selectedCount++;
- }
- }
- } else {
- if (!isSelected(item)) {
- isAllSelected = false;
- break;
- } else {
- selectedCount++;
- }
- }
- }
+ exports.__esModule = true;
- if (selectedCount === 0) isAllSelected = false;
+ 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; }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- states.isAllSelected = isAllSelected;
- };
+ var _emitter = __webpack_require__(15);
- TableStore.prototype.scheduleLayout = function () {
- this.table.debouncedLayout();
- };
+ var _emitter2 = _interopRequireDefault(_emitter);
- TableStore.prototype.setCurrentRowKey = function (key) {
- var states = this.states;
- var rowKey = states.rowKey;
- if (!rowKey) throw new Error('[Table] row-key should not be empty.');
- var data = states.data || [];
- var keysMap = getKeysMap(data, rowKey);
- var info = keysMap[key];
- if (info) {
- states.currentRow = info.row;
- }
- };
+ var _locale = __webpack_require__(10);
- TableStore.prototype.updateCurrentRow = function () {
- var states = this.states;
- var table = this.table;
- var data = states.data || [];
- var oldCurrentRow = states.currentRow;
+ var _locale2 = _interopRequireDefault(_locale);
- if (data.indexOf(oldCurrentRow) === -1) {
- states.currentRow = null;
+ var _input = __webpack_require__(20);
- if (states.currentRow !== oldCurrentRow) {
- table.$emit('current-change', null, oldCurrentRow);
- }
- }
- };
+ var _input2 = _interopRequireDefault(_input);
- TableStore.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];
- }
+ var _selectDropdown = __webpack_require__(102);
- mutations[name].apply(this, [this.states].concat(args));
- } else {
- throw new Error('Action not found: ' + name);
- }
- };
+ var _selectDropdown2 = _interopRequireDefault(_selectDropdown);
- exports.default = TableStore;
+ var _option = __webpack_require__(105);
-/***/ },
-/* 133 */
-/***/ function(module, exports) {
+ var _option2 = _interopRequireDefault(_option);
- module.exports = __webpack_require__(3);
+ var _tag = __webpack_require__(109);
-/***/ },
-/* 134 */
-/***/ function(module, exports, __webpack_require__) {
+ var _tag2 = _interopRequireDefault(_tag);
- 'use strict';
+ var _scrollbar = __webpack_require__(25);
- exports.__esModule = true;
- exports.getRowIdentity = exports.mousewheel = exports.getColumnByCell = exports.getColumnById = exports.orderBy = exports.getCell = undefined;
+ var _scrollbar2 = _interopRequireDefault(_scrollbar);
- 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; };
+ var _debounce = __webpack_require__(69);
- var _util = __webpack_require__(107);
+ var _debounce2 = _interopRequireDefault(_debounce);
- var getCell = exports.getCell = function getCell(event) {
- var cell = event.target;
+ var _clickoutside = __webpack_require__(21);
- while (cell && cell.tagName.toUpperCase() !== 'HTML') {
- if (cell.tagName.toUpperCase() === 'TD') {
- return cell;
- }
- cell = cell.parentNode;
- }
+ var _clickoutside2 = _interopRequireDefault(_clickoutside);
- return null;
- };
+ var _dom = __webpack_require__(44);
- var isObject = function isObject(obj) {
- return obj !== null && (typeof obj === 'undefined' ? 'undefined' : _typeof(obj)) === 'object';
- };
+ var _resizeEvent = __webpack_require__(110);
- var orderBy = exports.orderBy = function orderBy(array, sortKey, reverse, sortMethod) {
- if (typeof reverse === 'string') {
- reverse = reverse === 'descending' ? -1 : 1;
- }
- if (!sortKey && !sortMethod) {
- return array;
- }
- var order = reverse && reverse < 0 ? -1 : 1;
+ var _locale3 = __webpack_require__(111);
- // sort on a copy to avoid mutating original array
- return array.slice().sort(sortMethod ? function (a, b) {
- return sortMethod(a, b) ? order : -order;
- } : function (a, b) {
- if (sortKey !== '$key') {
- if (isObject(a) && '$value' in a) a = a.$value;
- if (isObject(b) && '$value' in b) b = b.$value;
- }
- a = isObject(a) ? (0, _util.getValueByPath)(a, sortKey) : a;
- b = isObject(b) ? (0, _util.getValueByPath)(b, sortKey) : b;
- return a === b ? 0 : a > b ? order : -order;
- });
- };
-
- var getColumnById = exports.getColumnById = function getColumnById(table, columnId) {
- var column = null;
- table.columns.forEach(function (item) {
- if (item.id === columnId) {
- column = item;
- }
- });
- return column;
- };
-
- var getColumnByCell = exports.getColumnByCell = function getColumnByCell(table, cell) {
- var matches = (cell.className || '').match(/el-table_[^\s]+/gm);
- if (matches) {
- return getColumnById(table, matches[0]);
- }
- return null;
- };
-
- var isFirefox = typeof navigator !== 'undefined' && navigator.userAgent.toLowerCase().indexOf('firefox') > -1;
-
- var mousewheel = exports.mousewheel = function mousewheel(element, callback) {
- if (element && element.addEventListener) {
- element.addEventListener(isFirefox ? 'DOMMouseScroll' : 'mousewheel', callback);
- }
- };
-
- var getRowIdentity = exports.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);
- }
- };
-
-/***/ },
-/* 135 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
+ var _scrollIntoView = __webpack_require__(112);
- var _scrollbarWidth = __webpack_require__(136);
+ var _scrollIntoView2 = _interopRequireDefault(_scrollIntoView);
- var _scrollbarWidth2 = _interopRequireDefault(_scrollbarWidth);
+ var _util = __webpack_require__(107);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+ var sizeMap = {
+ 'large': 42,
+ 'small': 30,
+ 'mini': 22
+ };
- var TableLayout = function () {
- function TableLayout(options) {
- _classCallCheck(this, TableLayout);
+ exports.default = {
+ mixins: [_emitter2.default, _locale2.default],
- this.table = null;
- this.store = null;
- this.columns = null;
- this.fit = true;
- this.showHeader = true;
+ name: 'ElSelect',
- 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.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 = (0, _scrollbarWidth2.default)();
+ componentName: 'ElSelect',
- for (var name in options) {
- if (options.hasOwnProperty(name)) {
- this[name] = options[name];
+ computed: {
+ iconClass: function iconClass() {
+ var criteria = this.clearable && !this.disabled && this.inputHovering && !this.multiple && this.value !== undefined && this.value !== '';
+ return criteria ? 'circle-close is-show-close' : this.remote && this.filterable ? '' : 'caret-top';
+ },
+ 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.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');
+ }
}
- }
-
- 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 (typeof height !== 'string' && typeof height !== 'number') return;
- var bodyWrapper = this.table.bodyWrapper;
- if (this.table.$el && bodyWrapper) {
- var body = bodyWrapper.querySelector('.el-table__body');
- this.scrollY = body.offsetHeight > bodyWrapper.offsetHeight;
- }
- };
-
- TableLayout.prototype.setHeight = function setHeight(value) {
- var prop = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'height';
+ return null;
+ },
+ showNewOption: function showNewOption() {
+ var _this = this;
- var el = this.table.$el;
- if (typeof value === 'string' && /^\d+$/.test(value)) {
- value = Number(value);
+ 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;
}
+ },
- this.height = value;
+ components: {
+ ElInput: _input2.default,
+ ElSelectMenu: _selectDropdown2.default,
+ ElOption: _option2.default,
+ ElTag: _tag2.default,
+ ElScrollbar: _scrollbar2.default
+ },
- if (!el) return;
- if (typeof value === 'number') {
- el.style[prop] = value + 'px';
+ directives: { Clickoutside: _clickoutside2.default },
- this.updateHeight();
- } else if (typeof value === 'string') {
- if (value === '') {
- el.style[prop] = '';
+ props: {
+ name: String,
+ value: {
+ required: true
+ },
+ 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 (0, _locale3.t)('el.select.placeholder');
}
- this.updateHeight();
+ },
+ defaultFirstOption: Boolean,
+ valueKey: {
+ type: String,
+ default: 'value'
}
- };
+ },
- TableLayout.prototype.setMaxHeight = function setMaxHeight(value) {
- return this.setHeight(value, 'max-height');
- };
+ data: function data() {
+ return {
+ options: [],
+ cachedOptions: [],
+ createdLabel: null,
+ createdSelected: false,
+ selected: this.multiple ? [] : {},
+ isSelect: true,
+ inputLength: 20,
+ inputWidth: 0,
+ cachedPlaceHolder: '',
+ optionsCount: 0,
+ filteredOptionsCount: 0,
+ visible: false,
+ selectedLabel: '',
+ hoverIndex: -1,
+ query: '',
+ optionsAllDisabled: false,
+ inputHovering: false,
+ currentPlaceholder: ''
+ };
+ },
- TableLayout.prototype.updateHeight = function updateHeight() {
- var height = this.tableHeight = this.table.$el.clientHeight;
- var noData = !this.table.data || this.table.data.length === 0;
- var _table$$refs = this.table.$refs,
- headerWrapper = _table$$refs.headerWrapper,
- footerWrapper = _table$$refs.footerWrapper;
- var footerHeight = this.footerHeight = footerWrapper ? footerWrapper.offsetHeight : 0;
- if (this.showHeader && !headerWrapper) return;
- if (!this.showHeader) {
- this.headerHeight = 0;
- if (this.height !== null && (!isNaN(this.height) || typeof this.height === 'string')) {
- this.bodyHeight = height - footerHeight + (footerWrapper ? 1 : 0);
+ watch: {
+ placeholder: function placeholder(val) {
+ this.cachedPlaceHolder = this.currentPlaceholder = val;
+ },
+ value: function value(val) {
+ if (this.multiple) {
+ this.resetInputHeight();
+ if (val.length > 0 || this.$refs.input && this.query !== '') {
+ this.currentPlaceholder = '';
+ } else {
+ this.currentPlaceholder = this.cachedPlaceHolder;
+ }
}
- this.fixedBodyHeight = this.scrollX ? height - this.gutterWidth : height;
- } else {
- var headerHeight = this.headerHeight = headerWrapper.offsetHeight;
- var bodyHeight = height - headerHeight - footerHeight + (footerWrapper ? 1 : 0);
- if (this.height !== null && (!isNaN(this.height) || typeof this.height === 'string')) {
- this.bodyHeight = bodyHeight;
+ this.setSelected();
+ if (this.filterable && !this.multiple) {
+ this.inputLength = 20;
}
- this.fixedBodyHeight = this.scrollX ? bodyHeight - this.gutterWidth : bodyHeight;
- }
- this.viewportHeight = this.scrollX ? height - (noData ? 0 : this.gutterWidth) : height;
- };
-
- TableLayout.prototype.update = function update() {
- var fit = this.fit;
- var columns = this.table.columns;
- var bodyWidth = this.table.$el.clientWidth;
- var bodyMinWidth = 0;
+ this.$emit('change', val);
+ this.dispatch('ElFormItem', 'el.form.change', val);
+ },
+ query: function query(val) {
+ var _this2 = this;
- var flattenColumns = [];
- columns.forEach(function (column) {
- if (column.isColumnGroup) {
- flattenColumns.push.apply(flattenColumns, column.columns);
+ this.$nextTick(function () {
+ if (_this2.visible) _this2.broadcast('ElSelectDropdown', 'updatePopper');
+ });
+ this.hoverIndex = -1;
+ if (this.multiple && this.filterable) {
+ this.inputLength = this.$refs.input.value.length * 15 + 20;
+ this.managePlaceholder();
+ this.resetInputHeight();
+ }
+ if (this.remote && typeof this.remoteMethod === 'function') {
+ this.hoverIndex = -1;
+ this.remoteMethod(val);
+ this.broadcast('ElOption', 'resetIndex');
+ } else if (typeof this.filterMethod === 'function') {
+ this.filterMethod(val);
+ this.broadcast('ElOptionGroup', 'queryChange');
} else {
- flattenColumns.push(column);
+ this.filteredOptionsCount = this.optionsCount;
+ this.broadcast('ElOption', 'queryChange', val);
+ this.broadcast('ElOptionGroup', 'queryChange');
}
- });
-
- var flexColumns = flattenColumns.filter(function (column) {
- return typeof column.width !== 'number';
- });
-
- if (flexColumns.length > 0 && fit) {
- flattenColumns.forEach(function (column) {
- bodyMinWidth += column.width || column.minWidth || 80;
- });
-
- if (bodyMinWidth < bodyWidth - this.gutterWidth) {
- // DON'T HAVE SCROLL BAR
- this.scrollX = false;
-
- var totalFlexWidth = bodyWidth - this.gutterWidth - bodyMinWidth;
-
- if (flexColumns.length === 1) {
- flexColumns[0].realWidth = (flexColumns[0].minWidth || 80) + totalFlexWidth;
- } else {
- (function () {
- 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;
- });
+ if (this.defaultFirstOption && (this.filterable || this.remote) && this.filteredOptionsCount) {
+ this.checkDefaultFirstOption();
+ }
+ },
+ visible: function visible(val) {
+ var _this3 = this;
- flexColumns[0].realWidth = (flexColumns[0].minWidth || 80) + totalFlexWidth - noneFirstWidth;
- })();
+ if (!val) {
+ this.$refs.reference.$el.querySelector('input').blur();
+ this.handleIconHide();
+ this.broadcast('ElSelectDropdown', 'destroyPopper');
+ if (this.$refs.input) {
+ this.$refs.input.blur();
}
- } else {
- // HAVE HORIZONTAL SCROLL BAR
- this.scrollX = true;
- flexColumns.forEach(function (column) {
- column.realWidth = column.minWidth;
+ this.query = '';
+ this.selectedLabel = '';
+ this.inputLength = 20;
+ this.resetHoverIndex();
+ this.$nextTick(function () {
+ if (_this3.$refs.input && _this3.$refs.input.value === '' && _this3.selected.length === 0) {
+ _this3.currentPlaceholder = _this3.cachedPlaceHolder;
+ }
});
- }
-
- this.bodyWidth = Math.max(bodyMinWidth, bodyWidth);
- } else {
- flattenColumns.forEach(function (column) {
- if (!column.width && !column.minWidth) {
- column.realWidth = 80;
- } else {
- column.realWidth = column.width || column.minWidth;
+ if (!this.multiple) {
+ if (this.selected) {
+ if (this.filterable && this.allowCreate && this.createdSelected && this.createdOption) {
+ this.selectedLabel = this.createdLabel;
+ } else {
+ this.selectedLabel = this.selected.currentLabel;
+ }
+ if (this.filterable) this.query = this.selectedLabel;
+ }
}
-
- bodyMinWidth += column.realWidth;
- });
- this.scrollX = bodyMinWidth > bodyWidth;
-
- this.bodyWidth = bodyMinWidth;
+ } else {
+ this.handleIconShow();
+ this.broadcast('ElSelectDropdown', 'updatePopper');
+ if (this.filterable) {
+ this.query = this.selectedLabel;
+ if (this.multiple) {
+ this.$refs.input.focus();
+ } else {
+ if (!this.remote) {
+ this.broadcast('ElOption', 'queryChange', '');
+ this.broadcast('ElOptionGroup', 'queryChange');
+ }
+ this.broadcast('ElInput', 'inputSelect');
+ }
+ }
+ }
+ this.$emit('visible-change', val);
+ },
+ options: function options(val) {
+ if (this.$isServer) return;
+ this.optionsAllDisabled = val.length === val.filter(function (item) {
+ return item.disabled === true;
+ }).length;
+ 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();
+ }
}
+ },
- var fixedColumns = this.store.states.fixedColumns;
+ methods: {
+ handleIconHide: function handleIconHide() {
+ var icon = this.$el.querySelector('.el-input__icon');
+ if (icon) {
+ (0, _dom.removeClass)(icon, 'is-reverse');
+ }
+ },
+ handleIconShow: function handleIconShow() {
+ var icon = this.$el.querySelector('.el-input__icon');
+ if (icon && !(0, _dom.hasClass)(icon, 'el-icon-circle-close')) {
+ (0, _dom.addClass)(icon, 'is-reverse');
+ }
+ },
+ 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');
+ (0, _scrollIntoView2.default)(menu, target);
+ }
+ },
+ handleMenuEnter: function handleMenuEnter() {
+ var _this4 = this;
- if (fixedColumns.length > 0) {
- var fixedWidth = 0;
- fixedColumns.forEach(function (column) {
- fixedWidth += column.realWidth;
+ this.$nextTick(function () {
+ return _this4.scrollToOption(_this4.selected);
});
+ },
+ getOption: function getOption(value) {
+ var option = void 0;
+ var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
+ for (var i = this.cachedOptions.length - 1; i >= 0; i--) {
+ var cachedOption = this.cachedOptions[i];
+ var isEqual = isObject ? (0, _util.getValueByPath)(cachedOption.value, this.valueKey) === (0, _util.getValueByPath)(value, this.valueKey) : cachedOption.value === value;
+ if (isEqual) {
+ option = cachedOption;
+ break;
+ }
+ }
+ if (option) return option;
+ var label = !isObject ? value : '';
+ var newOption = {
+ value: value,
+ currentLabel: label
+ };
+ if (this.multiple) {
+ newOption.hitState = false;
+ }
+ return newOption;
+ },
+ setSelected: function setSelected() {
+ var _this5 = this;
- this.fixedWidth = fixedWidth;
- }
-
- var rightFixedColumns = this.store.states.rightFixedColumns;
- if (rightFixedColumns.length > 0) {
- var rightFixedWidth = 0;
- rightFixedColumns.forEach(function (column) {
- rightFixedWidth += column.realWidth;
+ 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(_this5.getOption(value));
+ });
+ }
+ this.selected = result;
+ this.$nextTick(function () {
+ _this5.resetInputHeight();
});
-
- this.rightFixedWidth = rightFixedWidth;
- }
- };
-
- return TableLayout;
- }();
-
- exports.default = TableLayout;
-
-/***/ },
-/* 136 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(14);
-
-/***/ },
-/* 137 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _util = __webpack_require__(134);
-
- var _dom = __webpack_require__(44);
-
- var _checkbox = __webpack_require__(130);
-
- var _checkbox2 = _interopRequireDefault(_checkbox);
-
- var _tooltip = __webpack_require__(138);
-
- var _tooltip2 = _interopRequireDefault(_tooltip);
-
- var _debounce = __webpack_require__(69);
-
- var _debounce2 = _interopRequireDefault(_debounce);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = {
- components: {
- ElCheckbox: _checkbox2.default,
- ElTooltip: _tooltip2.default
- },
-
- props: {
- store: {
- required: true
},
- stripe: Boolean,
- context: {},
- layout: {
- required: true
+ handleFocus: function handleFocus() {
+ this.visible = true;
},
- rowClassName: [String, Function],
- rowStyle: [Object, Function],
- fixed: String,
- highlight: Boolean
- },
-
- render: function render(h) {
- var _this = this;
-
- var columnsHidden = this.columns.map(function (column, index) {
- return _this.isColumnHidden(index);
- });
- return h(
- 'table',
- {
- 'class': 'el-table__body',
- attrs: { cellspacing: '0',
- cellpadding: '0',
- border: '0' }
- },
- [h(
- 'colgroup',
- null,
- [this._l(this.columns, function (column) {
- return h(
- 'col',
- {
- attrs: {
- name: column.id,
- width: column.realWidth || column.width
- }
- },
- []
- );
- })]
- ), h(
- 'tbody',
- null,
- [this._l(this.data, function (row, $index) {
- return [h(
- 'tr',
- {
- style: _this.rowStyle ? _this.getRowStyle(row, $index) : null,
- key: _this.table.rowKey ? _this.getKeyOfRow(row, $index) : $index,
- on: {
- 'dblclick': function dblclick($event) {
- return _this.handleDoubleClick($event, row);
- },
- 'click': function click($event) {
- return _this.handleClick($event, row);
- },
- 'contextmenu': function contextmenu($event) {
- return _this.handleContextMenu($event, row);
- },
- 'mouseenter': function mouseenter(_) {
- return _this.handleMouseEnter($index);
- },
- 'mouseleave': function mouseleave(_) {
- return _this.handleMouseLeave();
- }
- },
-
- 'class': [_this.getRowClass(row, $index)] },
- [_this._l(_this.columns, function (column, cellIndex) {
- return h(
- 'td',
- {
- 'class': [column.id, column.align, column.className || '', columnsHidden[cellIndex] ? 'is-hidden' : ''],
- on: {
- 'mouseenter': function mouseenter($event) {
- return _this.handleCellMouseEnter($event, row);
- },
- 'mouseleave': _this.handleCellMouseLeave
- }
- },
- [column.renderCell.call(_this._renderProxy, h, { row: row, column: column, $index: $index, store: _this.store, _self: _this.context || _this.table.$vnode.context }, columnsHidden[cellIndex])]
- );
- }), !_this.fixed && _this.layout.scrollY && _this.layout.gutterWidth ? h(
- 'td',
- { 'class': 'gutter' },
- []
- ) : '']
- ), _this.store.states.expandRows.indexOf(row) > -1 ? h(
- 'tr',
- null,
- [h(
- 'td',
- {
- attrs: { colspan: _this.columns.length },
- 'class': 'el-table__expanded-cell' },
- [_this.table.renderExpanded ? _this.table.renderExpanded(h, { row: row, $index: $index, store: _this.store }) : '']
- )]
- ) : ''];
- }).concat(this._self.$parent.$slots.append).concat(h(
- 'el-tooltip',
- {
- attrs: { effect: this.table.tooltipEffect, placement: 'top', content: this.tooltipContent },
- ref: 'tooltip' },
- []
- ))]
- )]
- );
- },
-
-
- watch: {
- 'store.states.hoverRow': function storeStatesHoverRow(newVal, oldVal) {
- if (!this.store.states.isComplex) return;
- var el = this.$el;
- if (!el) return;
- var rows = el.querySelectorAll('tbody > tr.el-table__row');
- var oldRow = rows[oldVal];
- var newRow = rows[newVal];
- if (oldRow) {
- (0, _dom.removeClass)(oldRow, 'hover-row');
- }
- if (newRow) {
- (0, _dom.addClass)(newRow, 'hover-row');
+ handleIconClick: function handleIconClick(event) {
+ if (this.iconClass.indexOf('circle-close') > -1) {
+ this.deleteSelected(event);
+ } else {
+ this.toggleMenu();
}
},
- 'store.states.currentRow': function storeStatesCurrentRow(newVal, oldVal) {
- if (!this.highlight) return;
- var el = this.$el;
- if (!el) return;
- var data = this.store.states.data;
- var rows = el.querySelectorAll('tbody > tr.el-table__row');
- var oldRow = rows[data.indexOf(oldVal)];
- var newRow = rows[data.indexOf(newVal)];
- if (oldRow) {
- (0, _dom.removeClass)(oldRow, 'current-row');
- } else if (rows) {
- [].forEach.call(rows, function (row) {
- return (0, _dom.removeClass)(row, 'current-row');
- });
- }
- if (newRow) {
- (0, _dom.addClass)(newRow, 'current-row');
+ handleMouseDown: function handleMouseDown(event) {
+ if (event.target.tagName !== 'INPUT') return;
+ if (this.visible) {
+ this.handleClose();
+ event.preventDefault();
}
- }
- },
-
- computed: {
- table: function table() {
- return this.$parent;
- },
- data: function data() {
- return this.store.states.data;
- },
- columnsCount: function columnsCount() {
- return this.store.states.columns.length;
},
- leftFixedCount: function leftFixedCount() {
- return this.store.states.fixedColumns.length;
+ doDestroy: function doDestroy() {
+ this.$refs.popper && this.$refs.popper.doDestroy();
+ this.dropdownUl = null;
},
- rightFixedCount: function rightFixedCount() {
- return this.store.states.rightFixedColumns.length;
+ handleClose: function handleClose() {
+ this.visible = false;
},
- columns: function columns() {
- return this.store.states.columns;
- }
- },
-
- data: function data() {
- return {
- tooltipContent: ''
- };
- },
- created: function created() {
- this.activateTooltip = (0, _debounce2.default)(50, function (tooltip) {
- return tooltip.handleShowPopper();
- });
- },
-
+ toggleLastOptionHitState: function toggleLastOptionHitState(hit) {
+ if (!Array.isArray(this.selected)) return;
+ var option = this.selected[this.selected.length - 1];
+ if (!option) return;
- methods: {
- getKeyOfRow: function getKeyOfRow(row, index) {
- var rowKey = this.table.rowKey;
- if (rowKey) {
- return (0, _util.getRowIdentity)(row, rowKey);
+ if (hit === true || hit === false) {
+ option.hitState = hit;
+ return hit;
}
- return index;
+
+ option.hitState = !option.hitState;
+ return option.hitState;
},
- isColumnHidden: function isColumnHidden(index) {
- if (this.fixed === true || this.fixed === 'left') {
- return index >= this.leftFixedCount;
- } else if (this.fixed === 'right') {
- return index < this.columnsCount - this.rightFixedCount;
- } else {
- return index < this.leftFixedCount || index >= this.columnsCount - this.rightFixedCount;
+ deletePrevTag: function deletePrevTag(e) {
+ if (e.target.value.length <= 0 && !this.toggleLastOptionHitState()) {
+ var value = this.value.slice();
+ value.pop();
+ this.$emit('input', value);
}
},
- getRowStyle: function getRowStyle(row, index) {
- var rowStyle = this.rowStyle;
- if (typeof rowStyle === 'function') {
- return rowStyle.call(null, row, index);
+ managePlaceholder: function managePlaceholder() {
+ if (this.currentPlaceholder !== '') {
+ this.currentPlaceholder = this.$refs.input.value ? '' : this.cachedPlaceHolder;
}
- return rowStyle;
},
- getRowClass: function getRowClass(row, index) {
- var classes = ['el-table__row'];
+ 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 _this6 = this;
- if (this.stripe && index % 2 === 1) {
- classes.push('el-table__row--striped');
- }
- var rowClassName = this.rowClassName;
- if (typeof rowClassName === 'string') {
- classes.push(rowClassName);
- } else if (typeof rowClassName === 'function') {
- classes.push(rowClassName.call(null, row, index) || '');
- }
+ this.$nextTick(function () {
+ if (!_this6.$refs.reference) return;
+ var inputChildNodes = _this6.$refs.reference.$el.childNodes;
+ var input = [].filter.call(inputChildNodes, function (item) {
+ return item.tagName === 'INPUT';
+ })[0];
+ input.style.height = Math.max(_this6.$refs.tags.clientHeight + 6, sizeMap[_this6.size] || 36) + 'px';
+ if (_this6.visible && _this6.emptyText !== false) {
+ _this6.broadcast('ElSelectDropdown', 'updatePopper');
+ }
+ });
+ },
+ resetHoverIndex: function resetHoverIndex() {
+ var _this7 = this;
- return classes.join(' ');
+ setTimeout(function () {
+ if (!_this7.multiple) {
+ _this7.hoverIndex = _this7.options.indexOf(_this7.selected);
+ } else {
+ if (_this7.selected.length > 0) {
+ _this7.hoverIndex = Math.min.apply(null, _this7.selected.map(function (item) {
+ return _this7.options.indexOf(item);
+ }));
+ } else {
+ _this7.hoverIndex = -1;
+ }
+ }
+ }, 300);
},
- handleCellMouseEnter: function handleCellMouseEnter(event, row) {
- var table = this.table;
- var cell = (0, _util.getCell)(event);
+ handleOptionSelect: function handleOptionSelect(option) {
+ var _this8 = this;
- if (cell) {
- var column = (0, _util.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);
+ 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);
+ if (option.created) {
+ this.query = '';
+ this.inputLength = 20;
+ }
+ if (this.filterable) this.$refs.input.focus();
+ } else {
+ this.$emit('input', option.value);
+ this.visible = false;
}
+ this.$nextTick(function () {
+ return _this8.scrollToOption(option);
+ });
+ },
+ getValueIndex: function getValueIndex() {
+ var _this9 = this;
- // 判断是否text-overflow, 如果是就显示tooltip
- var cellChild = event.target.querySelector('.cell');
+ var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
+ var value = arguments[1];
- if ((0, _dom.hasClass)(cellChild, 'el-tooltip') && cellChild.scrollWidth > cellChild.offsetWidth) {
- var tooltip = this.$refs.tooltip;
+ var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
+ if (!isObject) {
+ return arr.indexOf(value);
+ } else {
+ var _ret = function () {
+ var valueKey = _this9.valueKey;
+ var index = -1;
+ arr.some(function (item, i) {
+ if ((0, _util.getValueByPath)(item, valueKey) === (0, _util.getValueByPath)(value, valueKey)) {
+ index = i;
+ return true;
+ }
+ return false;
+ });
+ return {
+ v: index
+ };
+ }();
- this.tooltipContent = cell.innerText;
- tooltip.referenceElm = cell;
- tooltip.$refs.popper && (tooltip.$refs.popper.style.display = 'none');
- tooltip.doDestroy();
- tooltip.setExpectedState(true);
- this.activateTooltip(tooltip);
+ if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
}
},
- handleCellMouseLeave: function handleCellMouseLeave(event) {
- var tooltip = this.$refs.tooltip;
- if (tooltip) {
- tooltip.setExpectedState(false);
- tooltip.handleClosePopper();
+ toggleMenu: function toggleMenu() {
+ if (this.filterable && this.query === '' && this.visible) {
+ return;
}
- var cell = (0, _util.getCell)(event);
- if (!cell) return;
+ if (!this.disabled) {
+ this.visible = !this.visible;
+ }
+ },
+ navigateOptions: function navigateOptions(direction) {
+ var _this10 = this;
- var oldHoverState = this.table.hoverState;
- this.table.$emit('cell-mouse-leave', oldHoverState.row, oldHoverState.column, oldHoverState.cell, event);
+ if (!this.visible) {
+ this.visible = true;
+ return;
+ }
+ if (this.options.length === 0 || this.filteredOptionsCount === 0) return;
+ this.optionsAllDisabled = this.options.length === this.options.filter(function (item) {
+ return item.disabled === true;
+ }).length;
+ if (!this.optionsAllDisabled) {
+ if (direction === 'next') {
+ this.hoverIndex++;
+ if (this.hoverIndex === this.options.length) {
+ this.hoverIndex = 0;
+ }
+ if (this.options[this.hoverIndex].disabled === true || this.options[this.hoverIndex].groupDisabled === true || !this.options[this.hoverIndex].visible) {
+ this.navigateOptions('next');
+ }
+ }
+ if (direction === 'prev') {
+ this.hoverIndex--;
+ if (this.hoverIndex < 0) {
+ this.hoverIndex = this.options.length - 1;
+ }
+ if (this.options[this.hoverIndex].disabled === true || this.options[this.hoverIndex].groupDisabled === true || !this.options[this.hoverIndex].visible) {
+ this.navigateOptions('prev');
+ }
+ }
+ }
+ this.$nextTick(function () {
+ return _this10.scrollToOption(_this10.options[_this10.hoverIndex]);
+ });
},
- handleMouseEnter: function handleMouseEnter(index) {
- this.store.commit('setHoverRow', index);
+ selectOption: function selectOption() {
+ if (this.options[this.hoverIndex]) {
+ this.handleOptionSelect(this.options[this.hoverIndex]);
+ }
},
- handleMouseLeave: function handleMouseLeave() {
- this.store.commit('setHoverRow', null);
+ deleteSelected: function deleteSelected(event) {
+ event.stopPropagation();
+ this.$emit('input', '');
+ this.visible = false;
+ this.$emit('clear');
},
- handleContextMenu: function handleContextMenu(event, row) {
- this.handleEvent(event, row, 'contextmenu');
+ deleteTag: function deleteTag(event, tag) {
+ var index = this.selected.indexOf(tag);
+ if (index > -1 && !this.disabled) {
+ var value = this.value.slice();
+ value.splice(index, 1);
+ this.$emit('input', value);
+ this.$emit('remove-tag', tag);
+ }
+ event.stopPropagation();
},
- handleDoubleClick: function handleDoubleClick(event, row) {
- this.handleEvent(event, row, 'dblclick');
+ onInputChange: function onInputChange() {
+ if (this.filterable) {
+ this.query = this.selectedLabel;
+ }
},
- handleClick: function handleClick(event, row) {
- this.store.commit('setCurrentRow', row);
- this.handleEvent(event, row, 'click');
+ onOptionDestroy: function onOptionDestroy(option) {
+ this.optionsCount--;
+ this.filteredOptionsCount--;
+ var index = this.options.indexOf(option);
+ if (index > -1) {
+ this.options.splice(index, 1);
+ }
+ this.broadcast('ElOption', 'resetIndex');
},
- handleEvent: function handleEvent(event, row, name) {
- var table = this.table;
- var cell = (0, _util.getCell)(event);
- var column = void 0;
- if (cell) {
- column = (0, _util.getColumnByCell)(table, cell);
- if (column) {
- table.$emit('cell-' + name, row, column, cell, event);
+ 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;
+ for (var i = 0; i !== this.options.length; ++i) {
+ var option = this.options[i];
+ if (this.query) {
+ // pick first options that passes the filter
+ if (!option.disabled && !option.groupDisabled && option.visible) {
+ this.hoverIndex = i;
+ break;
+ }
+ } else {
+ // pick currently selected option
+ if (option.itemSelected) {
+ this.hoverIndex = i;
+ break;
+ }
}
}
- table.$emit('row-' + name, row, event, column);
},
- handleExpandClick: function handleExpandClick(row) {
- this.store.commit('toggleRowExpanded', row);
+ getValueKey: function getValueKey(item) {
+ var type = _typeof(item.value);
+ if (type === 'number' || type === 'string') {
+ return item.value;
+ } else {
+ return (0, _util.getValueByPath)(item.value, this.valueKey);
+ }
}
- }
+ },
+
+ created: function created() {
+ var _this11 = 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.setSelected();
+
+ this.debouncedOnInputChange = (0, _debounce2.default)(this.debounce, function () {
+ _this11.onInputChange();
+ });
+
+ this.$on('handleOptionClick', this.handleOptionSelect);
+ this.$on('onOptionDestroy', this.onOptionDestroy);
+ this.$on('setSelected', this.setSelected);
+ },
+ mounted: function mounted() {
+ var _this12 = this;
+
+ if (this.multiple && Array.isArray(this.value) && this.value.length > 0) {
+ this.currentPlaceholder = '';
+ }
+ (0, _resizeEvent.addResizeListener)(this.$el, this.handleResize);
+ if (this.remote && this.multiple) {
+ this.resetInputHeight();
+ }
+ this.$nextTick(function () {
+ if (_this12.$refs.reference && _this12.$refs.reference.$el) {
+ _this12.inputWidth = _this12.$refs.reference.$el.getBoundingClientRect().width;
+ }
+ });
+ },
+ beforeDestroy: function beforeDestroy() {
+ if (this.$el && this.handleResize) (0, _resizeEvent.removeResizeListener)(this.$el, this.handleResize);
+ }
};
/***/ },
-/* 138 */
-/***/ function(module, exports) {
+/* 102 */
+/***/ function(module, exports, __webpack_require__) {
+
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(103),
+ /* template */
+ __webpack_require__(104),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
+
+ module.exports = Component.exports
- module.exports = __webpack_require__(52);
/***/ },
-/* 139 */
+/* 103 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _dom = __webpack_require__(44);
+ var _vuePopper = __webpack_require__(24);
- var _checkbox = __webpack_require__(130);
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
- var _checkbox2 = _interopRequireDefault(_checkbox);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var _tag = __webpack_require__(109);
+ exports.default = {
+ name: 'ElSelectDropdown',
- var _tag2 = _interopRequireDefault(_tag);
+ componentName: 'ElSelectDropdown',
- var _vue = __webpack_require__(133);
+ mixins: [_vuePopper2.default],
- var _vue2 = _interopRequireDefault(_vue);
+ props: {
+ placement: {
+ default: 'bottom-start'
+ },
- var _filterPanel = __webpack_require__(140);
+ boundariesPadding: {
+ default: 0
+ },
- var _filterPanel2 = _interopRequireDefault(_filterPanel);
+ popperOptions: {
+ default: function _default() {
+ return {
+ forceAbsolute: true,
+ gpuAcceleration: false
+ };
+ }
+ }
+ },
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ data: function data() {
+ return {
+ minWidth: ''
+ };
+ },
- 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;
- }
+ computed: {
+ popperClass: function popperClass() {
+ return this.$parent.popperClass;
}
- if (column.children) {
- var colSpan = 0;
- column.children.forEach(function (subColumn) {
- traverse(subColumn, column);
- colSpan += subColumn.colSpan;
- });
- column.colSpan = colSpan;
- } else {
- column.colSpan = 1;
+ },
+
+ watch: {
+ '$parent.inputWidth': function $parentInputWidth() {
+ this.minWidth = this.$parent.$el.getBoundingClientRect().width + 'px';
}
- };
+ },
- originColumns.forEach(function (column) {
- column.level = 1;
- traverse(column);
- });
+ mounted: function mounted() {
+ var _this = this;
- var rows = [];
- for (var i = 0; i < maxLevel; i++) {
- rows.push([]);
+ 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);
}
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var allColumns = getAllColumns(originColumns);
+/***/ },
+/* 104 */
+/***/ function(module, exports) {
- allColumns.forEach(function (column) {
- if (!column.children) {
- column.rowSpan = maxLevel - column.level + 1;
- } else {
- column.rowSpan = 1;
- }
- rows[column.level - 1].push(column);
- });
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-select-dropdown",
+ class: [{
+ 'is-multiple': _vm.$parent.multiple
+ }, _vm.popperClass],
+ style: ({
+ minWidth: _vm.minWidth
+ })
+ }, [_vm._t("default")], 2)
+ },staticRenderFns: []}
- return rows;
- };
+/***/ },
+/* 105 */
+/***/ function(module, exports, __webpack_require__) {
- exports.default = {
- name: 'ElTableHeader',
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(106),
+ /* template */
+ __webpack_require__(108),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- render: function render(h) {
- var _this = this;
+ module.exports = Component.exports
- var originColumns = this.store.states.originColumns;
- var columnRows = convertToRows(originColumns, this.columns);
- return h(
- 'table',
- {
- 'class': 'el-table__header',
- attrs: { cellspacing: '0',
- cellpadding: '0',
- border: '0' }
- },
- [h(
- 'colgroup',
- null,
- [this._l(this.columns, function (column) {
- return h(
- 'col',
- {
- attrs: {
- name: column.id,
- width: column.realWidth || column.width
- }
- },
- []
- );
- }), !this.fixed && this.layout.gutterWidth ? h(
- 'col',
- {
- attrs: { name: 'gutter', width: this.layout.scrollY ? this.layout.gutterWidth : '' }
- },
- []
- ) : '']
- ), h(
- 'thead',
- null,
- [this._l(columnRows, function (columns, rowIndex) {
- return h(
- 'tr',
- null,
- [_this._l(columns, 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);
- }
- },
+/***/ },
+/* 106 */
+/***/ function(module, exports, __webpack_require__) {
- 'class': [column.id, column.order, column.headerAlign, column.className || '', rowIndex === 0 && _this.isCellHidden(cellIndex, columns) ? 'is-hidden' : '', !column.children ? 'is-leaf' : '', column.labelClassName] },
- [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.fixed && _this.layout.gutterWidth ? h(
- 'th',
- { 'class': 'gutter', style: { width: _this.layout.scrollY ? _this.layout.gutterWidth + 'px' : '0' } },
- []
- ) : '']
- );
- })]
- )]
- );
- },
+ 'use strict';
+
+ exports.__esModule = true;
+
+ 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; }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+ var _emitter = __webpack_require__(15);
+
+ var _emitter2 = _interopRequireDefault(_emitter);
+ var _util = __webpack_require__(107);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ exports.default = {
+ mixins: [_emitter2.default],
+
+ name: 'ElOption',
+
+ componentName: 'ElOption',
props: {
- fixed: String,
- store: {
- required: true
- },
- layout: {
+ value: {
required: true
},
- border: Boolean,
- defaultSort: {
- type: Object,
- default: function _default() {
- return {
- prop: '',
- order: ''
- };
- }
+ label: [String, Number],
+ created: Boolean,
+ disabled: {
+ type: Boolean,
+ default: false
}
},
- components: {
- ElCheckbox: _checkbox2.default,
- ElTag: _tag2.default
+ data: function data() {
+ return {
+ index: -1,
+ groupDisabled: false,
+ visible: true,
+ hitState: false
+ };
},
+
computed: {
- isAllSelected: function isAllSelected() {
- return this.store.states.isAllSelected;
+ isObject: function isObject() {
+ return Object.prototype.toString.call(this.value).toLowerCase() === '[object object]';
},
- columnsCount: function columnsCount() {
- return this.store.states.columns.length;
+ currentLabel: function currentLabel() {
+ return this.label || (this.isObject ? '' : this.value);
},
- leftFixedCount: function leftFixedCount() {
- return this.store.states.fixedColumns.length;
+ currentValue: function currentValue() {
+ return this.value || this.label || '';
},
- rightFixedCount: function rightFixedCount() {
- return this.store.states.rightFixedColumns.length;
+ parent: function parent() {
+ var result = this.$parent;
+ while (!result.isSelect) {
+ result = result.$parent;
+ }
+ return result;
},
- columns: function columns() {
- return this.store.states.columns;
+ itemSelected: function itemSelected() {
+ if (!this.parent.multiple) {
+ return this.isEqual(this.value, this.parent.value);
+ } else {
+ return this.contains(this.parent.value, this.value);
+ }
+ },
+ limitReached: function limitReached() {
+ if (this.parent.multiple) {
+ return !this.itemSelected && this.parent.value.length >= this.parent.multipleLimit && this.parent.multipleLimit > 0;
+ } else {
+ return false;
+ }
}
},
- created: function created() {
- this.filterPanels = {};
- },
- mounted: function mounted() {
- var _this2 = this;
-
- if (this.defaultSort.prop) {
- (function () {
- var states = _this2.store.states;
- states.sortProp = _this2.defaultSort.prop;
- states.sortOrder = _this2.defaultSort.order || 'ascending';
- _this2.$nextTick(function (_) {
- for (var i = 0, length = _this2.columns.length; i < length; i++) {
- var column = _this2.columns[i];
- if (column.property === states.sortProp) {
- column.order = states.sortOrder;
- states.sortingColumn = column;
- break;
- }
- }
-
- if (states.sortingColumn) {
- _this2.store.commit('changeSortCondition');
- }
- });
- })();
- }
- },
- beforeDestroy: function beforeDestroy() {
- var panels = this.filterPanels;
- for (var prop in panels) {
- if (panels.hasOwnProperty(prop) && panels[prop]) {
- panels[prop].$destroy(true);
- }
+ watch: {
+ currentLabel: function currentLabel() {
+ if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
+ },
+ value: function value() {
+ if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
}
},
-
methods: {
- isCellHidden: function isCellHidden(index, columns) {
- if (this.fixed === true || this.fixed === 'left') {
- return index >= this.leftFixedCount;
- } else if (this.fixed === 'right') {
- var before = 0;
- for (var i = 0; i < index; i++) {
- before += columns[i].colSpan;
- }
- return before < this.columnsCount - this.rightFixedCount;
+ isEqual: function isEqual(a, b) {
+ if (!this.isObject) {
+ return a === b;
} else {
- return index < this.leftFixedCount || index >= this.columnsCount - this.rightFixedCount;
+ var valueKey = this.parent.valueKey;
+ return (0, _util.getValueByPath)(a, valueKey) === (0, _util.getValueByPath)(b, valueKey);
}
},
- toggleAllSelection: function toggleAllSelection() {
- this.store.commit('toggleAllSelection');
- },
- handleFilterClick: function handleFilterClick(event, column) {
- event.stopPropagation();
- var target = event.target;
- var cell = target.parentNode;
- var table = this.$parent;
+ contains: function contains() {
+ var _this = this;
- var filterPanel = this.filterPanels[column.id];
+ var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
+ var target = arguments[1];
- if (filterPanel && column.filterOpened) {
- filterPanel.showPopper = false;
- return;
- }
+ if (!this.isObject) {
+ return arr.indexOf(target) > -1;
+ } else {
+ var _ret = function () {
+ var valueKey = _this.parent.valueKey;
+ return {
+ v: arr.some(function (item) {
+ return (0, _util.getValueByPath)(item, valueKey) === (0, _util.getValueByPath)(target, valueKey);
+ })
+ };
+ }();
- if (!filterPanel) {
- filterPanel = new _vue2.default(_filterPanel2.default);
- 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'));
+ if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
}
-
- setTimeout(function () {
- filterPanel.showPopper = true;
- }, 16);
},
- handleHeaderClick: function handleHeaderClick(event, column) {
- if (!column.filters && column.sortable) {
- this.handleSortClick(event, column);
- } else if (column.filters && !column.sortable) {
- this.handleFilterClick(event, column);
+ handleGroupDisabled: function handleGroupDisabled(val) {
+ this.groupDisabled = val;
+ },
+ hoverItem: function hoverItem() {
+ if (!this.disabled && !this.groupDisabled) {
+ this.parent.hoverIndex = this.parent.options.indexOf(this);
}
-
- this.$parent.$emit('header-click', column, event);
},
- handleMouseDown: function handleMouseDown(event, column) {
- var _this3 = this;
+ selectOptionClick: function selectOptionClick() {
+ if (this.disabled !== true && this.groupDisabled !== true) {
+ this.dispatch('ElSelect', 'handleOptionClick', this);
+ }
+ },
+ queryChange: function queryChange(query) {
+ // query 里如果有正则中的特殊字符,需要先将这些字符转义
+ var parsedQuery = String(query).replace(/(\^|\(|\)|\[|\]|\$|\*|\+|\.|\?|\\|\{|\}|\|)/g, '\\$1');
+ this.visible = new RegExp(parsedQuery, 'i').test(this.currentLabel) || this.created;
+ if (!this.visible) {
+ this.parent.filteredOptionsCount--;
+ }
+ },
+ resetIndex: function resetIndex() {
+ var _this2 = this;
- if (this.$isServer) return;
- if (column.children && column.children.length > 0) return;
- /* istanbul ignore if */
- if (this.draggingColumn && this.border) {
- (function () {
- _this3.dragging = true;
+ this.$nextTick(function () {
+ _this2.index = _this2.parent.options.indexOf(_this2);
+ });
+ }
+ },
- _this3.$parent.resizeProxyVisible = true;
+ created: function created() {
+ this.parent.options.push(this);
+ this.parent.cachedOptions.push(this);
+ this.parent.optionsCount++;
+ this.parent.filteredOptionsCount++;
+ this.index = this.parent.options.indexOf(this);
- var table = _this3.$parent;
- var tableEl = table.$el;
- var tableLeft = tableEl.getBoundingClientRect().left;
- var columnEl = _this3.$el.querySelector('th.' + column.id);
- var columnRect = columnEl.getBoundingClientRect();
- var minLeft = columnRect.left - tableLeft + 30;
+ this.$on('queryChange', this.queryChange);
+ this.$on('handleGroupDisabled', this.handleGroupDisabled);
+ this.$on('resetIndex', this.resetIndex);
+ },
+ beforeDestroy: function beforeDestroy() {
+ this.dispatch('ElSelect', 'onOptionDestroy', this);
+ }
+ };
- (0, _dom.addClass)(columnEl, 'noclick');
+/***/ },
+/* 107 */
+/***/ function(module, exports) {
- _this3.dragState = {
- startMouseLeft: event.clientX,
- startLeft: columnRect.right - tableLeft,
- startColumnLeft: columnRect.left - tableLeft,
- tableLeft: tableLeft
- };
+ module.exports = __webpack_require__(6);
- var resizeProxy = table.$refs.resizeProxy;
- resizeProxy.style.left = _this3.dragState.startLeft + 'px';
+/***/ },
+/* 108 */
+/***/ function(module, exports) {
- document.onselectstart = function () {
- return false;
- };
- document.ondragstart = function () {
- return false;
- };
+ module.exports={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.parent.hoverIndex === _vm.index
+ },
+ on: {
+ "mouseenter": _vm.hoverItem,
+ "click": function($event) {
+ $event.stopPropagation();
+ _vm.selectOptionClick($event)
+ }
+ }
+ }, [_vm._t("default", [_c('span', [_vm._v(_vm._s(_vm.currentLabel))])])], 2)
+ },staticRenderFns: []}
- var handleMouseMove = function handleMouseMove(event) {
- var deltaLeft = event.clientX - _this3.dragState.startMouseLeft;
- var proxyLeft = _this3.dragState.startLeft + deltaLeft;
+/***/ },
+/* 109 */
+/***/ function(module, exports) {
- resizeProxy.style.left = Math.max(minLeft, proxyLeft) + 'px';
- };
+ module.exports = __webpack_require__(26);
- var handleMouseUp = function handleMouseUp() {
- if (_this3.dragging) {
- var _dragState = _this3.dragState,
- startColumnLeft = _dragState.startColumnLeft,
- startLeft = _dragState.startLeft;
+/***/ },
+/* 110 */
+/***/ function(module, exports) {
- 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);
+ module.exports = __webpack_require__(15);
- _this3.store.scheduleLayout();
+/***/ },
+/* 111 */
+/***/ function(module, exports) {
- document.body.style.cursor = '';
- _this3.dragging = false;
- _this3.draggingColumn = null;
- _this3.dragState = {};
+ module.exports = __webpack_require__(16);
- table.resizeProxyVisible = false;
- }
+/***/ },
+/* 112 */
+/***/ function(module, exports) {
- document.removeEventListener('mousemove', handleMouseMove);
- document.removeEventListener('mouseup', handleMouseUp);
- document.onselectstart = null;
- document.ondragstart = null;
+ module.exports = __webpack_require__(23);
- setTimeout(function () {
- (0, _dom.removeClass)(columnEl, 'noclick');
- }, 0);
- };
+/***/ },
+/* 113 */
+/***/ function(module, exports) {
- document.addEventListener('mousemove', handleMouseMove);
- document.addEventListener('mouseup', handleMouseUp);
- })();
+ module.exports={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"
+ }, [(_vm.multiple) ? _c('div', {
+ ref: "tags",
+ staticClass: "el-select__tags",
+ style: ({
+ 'max-width': _vm.inputWidth - 32 + 'px'
+ }),
+ on: {
+ "click": function($event) {
+ $event.stopPropagation();
+ _vm.toggleMenu($event)
}
+ }
+ }, [_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.disabled,
+ "hit": item.hitState,
+ "type": "primary",
+ "close-transition": ""
+ },
+ on: {
+ "close": function($event) {
+ _vm.deleteTag($event, item)
+ }
+ }
+ }, [_c('span', {
+ staticClass: "el-select__tags-text"
+ }, [_vm._v(_vm._s(item.currentLabel))])])
+ })), (_vm.filterable) ? _c('input', {
+ directives: [{
+ name: "model",
+ rawName: "v-model",
+ value: (_vm.query),
+ expression: "query"
+ }],
+ ref: "input",
+ staticClass: "el-select__input",
+ class: ("is-" + _vm.size),
+ style: ({
+ width: _vm.inputLength + 'px',
+ 'max-width': _vm.inputWidth - 42 + 'px'
+ }),
+ attrs: {
+ "type": "text",
+ "disabled": _vm.disabled,
+ "debounce": _vm.remote ? 300 : 0
},
- 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;
+ domProps: {
+ "value": (_vm.query)
+ },
+ on: {
+ "focus": function($event) {
+ _vm.visible = true
+ },
+ "keyup": _vm.managePlaceholder,
+ "keydown": [_vm.resetInputState, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
+ $event.preventDefault();
+ _vm.navigateOptions('next')
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
+ $event.preventDefault();
+ _vm.navigateOptions('prev')
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
+ $event.preventDefault();
+ _vm.selectOption($event)
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "esc", 27)) { return null; }
+ $event.stopPropagation();
+ $event.preventDefault();
+ _vm.visible = false
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "delete", [8, 46])) { return null; }
+ _vm.deletePrevTag($event)
+ }],
+ "input": function($event) {
+ if ($event.target.composing) { return; }
+ _vm.query = $event.target.value
}
-
- 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';
- this.draggingColumn = column;
- } else if (!this.dragging) {
- bodyStyle.cursor = '';
- this.draggingColumn = null;
- }
+ }
+ }) : _vm._e()], 1) : _vm._e(), _c('el-input', {
+ ref: "reference",
+ attrs: {
+ "type": "text",
+ "placeholder": _vm.currentPlaceholder,
+ "name": _vm.name,
+ "size": _vm.size,
+ "disabled": _vm.disabled,
+ "readonly": !_vm.filterable || _vm.multiple,
+ "validate-event": false,
+ "icon": _vm.iconClass
+ },
+ on: {
+ "focus": _vm.handleFocus,
+ "click": _vm.handleIconClick
+ },
+ nativeOn: {
+ "mousedown": function($event) {
+ _vm.handleMouseDown($event)
+ },
+ "keyup": function($event) {
+ _vm.debouncedOnInputChange($event)
+ },
+ "keydown": [function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
+ $event.preventDefault();
+ _vm.navigateOptions('next')
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
+ $event.preventDefault();
+ _vm.navigateOptions('prev')
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
+ $event.preventDefault();
+ _vm.selectOption($event)
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "esc", 27)) { return null; }
+ $event.stopPropagation();
+ $event.preventDefault();
+ _vm.visible = false
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "tab", 9)) { return null; }
+ _vm.visible = false
+ }],
+ "paste": function($event) {
+ _vm.debouncedOnInputChange($event)
+ },
+ "mouseenter": function($event) {
+ _vm.inputHovering = true
+ },
+ "mouseleave": function($event) {
+ _vm.inputHovering = false
}
},
- handleMouseOut: function handleMouseOut() {
- if (this.$isServer) return;
- document.body.style.cursor = '';
+ model: {
+ value: (_vm.selectedLabel),
+ callback: function($$v) {
+ _vm.selectedLabel = $$v
+ },
+ expression: "selectedLabel"
+ }
+ }), _c('transition', {
+ attrs: {
+ "name": "el-zoom-in-top"
},
- toggleOrder: function toggleOrder(order) {
- return !order ? 'ascending' : order === 'ascending' ? 'descending' : null;
+ 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"
+ }, [_c('el-scrollbar', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.options.length > 0 && !_vm.loading),
+ expression: "options.length > 0 && !loading"
+ }],
+ class: {
+ 'is-empty': !_vm.allowCreate && _vm.filteredOptionsCount === 0
},
- handleSortClick: function handleSortClick(event, column, givenOrder) {
- event.stopPropagation();
- var order = givenOrder || this.toggleOrder(column.order);
+ 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.options.length === 0 || !_vm.allowCreate)) ? _c('p', {
+ staticClass: "el-select-dropdown__empty"
+ }, [_vm._v(_vm._s(_vm.emptyText))]) : _vm._e()], 1)], 1)], 1)
+ },staticRenderFns: []}
- var target = event.target;
- while (target && target.tagName !== 'TH') {
- target = target.parentNode;
- }
+/***/ },
+/* 114 */
+/***/ function(module, exports, __webpack_require__) {
- if (target && target.tagName === 'TH') {
- if ((0, _dom.hasClass)(target, 'noclick')) {
- (0, _dom.removeClass)(target, 'noclick');
- return;
- }
- }
+ 'use strict';
- if (!column.sortable) return;
+ exports.__esModule = true;
- var states = this.store.states;
- var sortProp = states.sortProp;
- var sortOrder = void 0;
- var sortingColumn = states.sortingColumn;
+ var _option = __webpack_require__(105);
- if (sortingColumn !== column) {
- if (sortingColumn) {
- sortingColumn.order = null;
- }
- states.sortingColumn = column;
- sortProp = column.property;
- }
+ var _option2 = _interopRequireDefault(_option);
- if (!order) {
- sortOrder = column.order = null;
- states.sortingColumn = null;
- sortProp = null;
- } else {
- sortOrder = column.order = order;
- }
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- states.sortProp = sortProp;
- states.sortOrder = sortOrder;
+ /* istanbul ignore next */
+ _option2.default.install = function (Vue) {
+ Vue.component(_option2.default.name, _option2.default);
+ };
- this.store.commit('changeSortCondition');
- }
- },
+ exports.default = _option2.default;
- data: function data() {
- return {
- draggingColumn: null,
- dragging: false,
- dragState: {}
- };
- }
+/***/ },
+/* 115 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _optionGroup = __webpack_require__(116);
+
+ var _optionGroup2 = _interopRequireDefault(_optionGroup);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _optionGroup2.default.install = function (Vue) {
+ Vue.component(_optionGroup2.default.name, _optionGroup2.default);
};
+ exports.default = _optionGroup2.default;
+
/***/ },
-/* 140 */
+/* 116 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(141),
+ __webpack_require__(117),
/* template */
- __webpack_require__(144),
+ __webpack_require__(118),
/* styles */
null,
/* scopeId */
@@ -43294,222 +42149,143 @@ module.exports =
/***/ },
-/* 141 */
+/* 117 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _vuePopper = __webpack_require__(24);
+ var _emitter = __webpack_require__(15);
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
+ var _emitter2 = _interopRequireDefault(_emitter);
- var _popup = __webpack_require__(14);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var _locale = __webpack_require__(10);
+ exports.default = {
+ mixins: [_emitter2.default],
- var _locale2 = _interopRequireDefault(_locale);
+ name: 'ElOptionGroup',
- var _clickoutside = __webpack_require__(21);
+ componentName: 'ElOptionGroup',
- var _clickoutside2 = _interopRequireDefault(_clickoutside);
+ props: {
+ label: String,
+ disabled: {
+ type: Boolean,
+ default: false
+ }
+ },
- var _dropdown = __webpack_require__(142);
+ data: function data() {
+ return {
+ visible: true
+ };
+ },
- var _dropdown2 = _interopRequireDefault(_dropdown);
- var _checkbox = __webpack_require__(130);
+ watch: {
+ disabled: function disabled(val) {
+ this.broadcast('ElOption', 'handleGroupDisabled', val);
+ }
+ },
- var _checkbox2 = _interopRequireDefault(_checkbox);
+ methods: {
+ queryChange: function queryChange() {
+ this.visible = this.$children && Array.isArray(this.$children) && this.$children.some(function (option) {
+ return option.visible === true;
+ });
+ }
+ },
- var _checkboxGroup = __webpack_require__(143);
-
- var _checkboxGroup2 = _interopRequireDefault(_checkboxGroup);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = {
- name: 'ElTableFilterPanel',
-
- mixins: [_vuePopper2.default, _locale2.default],
-
- directives: {
- Clickoutside: _clickoutside2.default
- },
-
- components: {
- ElCheckbox: _checkbox2.default,
- ElCheckboxGroup: _checkboxGroup2.default
+ created: function created() {
+ this.$on('queryChange', this.queryChange);
},
-
- props: {
- placement: {
- type: String,
- default: 'bottom-end'
+ mounted: function mounted() {
+ if (this.disabled) {
+ this.broadcast('ElOption', 'handleGroupDisabled', this.disabled);
}
- },
+ }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- customRender: function customRender(h) {
- return h(
- 'div',
- { 'class': 'el-table-filter' },
- [h(
- 'div',
- { 'class': 'el-table-filter__content' },
- []
- ), h(
- 'div',
- { 'class': 'el-table-filter__bottom' },
- [h(
- 'button',
- {
- on: {
- 'click': this.handleConfirm
- }
- },
- [this.t('el.table.confirmFilter')]
- ), h(
- 'button',
- {
- on: {
- 'click': this.handleReset
- }
- },
- [this.t('el.table.resetFilter')]
- )]
- )]
- );
- },
+/***/ },
+/* 118 */
+/***/ function(module, exports) {
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('ul', {
+ staticClass: "el-select-group__wrap"
+ }, [_c('li', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.visible),
+ expression: "visible"
+ }],
+ staticClass: "el-select-group__title"
+ }, [_vm._v(_vm._s(_vm.label))]), _c('li', [_c('ul', {
+ staticClass: "el-select-group"
+ }, [_vm._t("default")], 2)])])
+ },staticRenderFns: []}
- methods: {
- isActive: function isActive(filter) {
- return filter.value === this.filterValue;
- },
- handleOutsideClick: function handleOutsideClick() {
- this.showPopper = false;
- },
- 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;
+/***/ },
+/* 119 */
+/***/ function(module, exports, __webpack_require__) {
- if (typeof filterValue !== 'undefined' && filterValue !== null) {
- this.confirmFilter(this.filteredValue);
- } else {
- this.confirmFilter([]);
- }
+ 'use strict';
- this.handleOutsideClick();
- },
- confirmFilter: function confirmFilter(filteredValue) {
- this.table.store.commit('filterChange', {
- column: this.column,
- values: filteredValue
- });
- }
- },
+ exports.__esModule = true;
- data: function data() {
- return {
- table: null,
- cell: null,
- column: null
- };
- },
+ var _button = __webpack_require__(120);
+ var _button2 = _interopRequireDefault(_button);
- computed: {
- filters: function filters() {
- return this.column && this.column.filters;
- },
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ /* istanbul ignore next */
+ _button2.default.install = function (Vue) {
+ Vue.component(_button2.default.name, _button2.default);
+ };
- 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);
- }
- }
- }
- },
+ exports.default = _button2.default;
- filteredValue: {
- get: function get() {
- if (this.column) {
- return this.column.filteredValue || [];
- }
- return [];
- },
- set: function set(value) {
- if (this.column) {
- this.column.filteredValue = value;
- }
- }
- },
+/***/ },
+/* 120 */
+/***/ function(module, exports, __webpack_require__) {
- multiple: function multiple() {
- if (this.column) {
- return this.column.filterMultiple;
- }
- return true;
- }
- },
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(121),
+ /* template */
+ __webpack_require__(122),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- mounted: function mounted() {
- var _this = this;
+ module.exports = Component.exports
- this.popperElm = this.$el;
- this.referenceElm = this.cell;
- this.table.bodyWrapper.addEventListener('scroll', function () {
- _this.updatePopper();
- });
- this.$watch('showPopper', function (value) {
- if (_this.column) _this.column.filterOpened = value;
- if (value) {
- _dropdown2.default.open(_this);
- } else {
- _dropdown2.default.close(_this);
- }
- });
- },
+/***/ },
+/* 121 */
+/***/ function(module, exports) {
- 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();
- }
- }
- }
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ 'use strict';
+
+ exports.__esModule = true;
//
//
//
@@ -43531,558 +42307,198 @@ module.exports =
//
//
-/***/ },
-/* 142 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _vue = __webpack_require__(133);
-
- var _vue2 = _interopRequireDefault(_vue);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- var dropdowns = [];
-
- !_vue2.default.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);
- });
- });
-
exports.default = {
- open: function open(instance) {
- if (instance) {
- dropdowns.push(instance);
- }
+ name: 'ElButton',
+
+ 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
},
- close: function close(instance) {
- var index = dropdowns.indexOf(instance);
- if (index !== -1) {
- dropdowns.splice(instance, 1);
+
+ methods: {
+ handleClick: function handleClick(evt) {
+ this.$emit('click', evt);
+ },
+ handleInnerClick: function handleInnerClick(evt) {
+ if (this.disabled) {
+ evt.stopPropagation();
+ }
}
}
};
/***/ },
-/* 143 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(53);
-
-/***/ },
-/* 144 */
+/* 122 */
/***/ function(module, exports) {
module.exports={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: "show",
- rawName: "v-show",
- value: (_vm.showPopper),
- expression: "showPopper"
- }],
- staticClass: "el-table-filter"
- }, [_c('div', {
- staticClass: "el-table-filter__content"
- }, [_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
+ return _c('button', {
+ staticClass: "el-button",
+ class: [
+ _vm.type ? 'el-button--' + _vm.type : '',
+ _vm.size ? 'el-button--' + _vm.size : '', {
+ 'is-disabled': _vm.disabled,
+ 'is-loading': _vm.loading,
+ 'is-plain': _vm.plain
}
- }, [_vm._v(_vm._s(filter.text))])
- }))], 1), _c('div', {
- staticClass: "el-table-filter__bottom"
- }, [_c('button', {
- class: {
- 'is-disabled': _vm.filteredValue.length === 0
- },
+ ],
attrs: {
- "disabled": _vm.filteredValue.length === 0
+ "disabled": _vm.disabled,
+ "autofocus": _vm.autofocus,
+ "type": _vm.nativeType
},
on: {
- "click": _vm.handleConfirm
+ "click": _vm.handleClick
}
- }, [_vm._v(_vm._s(_vm.t('el.table.confirmFilter')))]), _c('button', {
+ }, [(_vm.loading) ? _c('i', {
+ staticClass: "el-icon-loading",
on: {
- "click": _vm.handleReset
+ "click": _vm.handleInnerClick
}
- }, [_vm._v(_vm._s(_vm.t('el.table.resetFilter')))])])]) : _c('div', {
- directives: [{
- 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
- },
+ }) : _vm._e(), (_vm.icon && !_vm.loading) ? _c('i', {
+ class: 'el-icon-' + _vm.icon,
on: {
- "click": function($event) {
- _vm.handleSelect(null)
- }
+ "click": _vm.handleInnerClick
}
- }, [_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)])])
+ }) : _vm._e(), (_vm.$slots.default) ? _c('span', {
+ on: {
+ "click": _vm.handleInnerClick
+ }
+ }, [_vm._t("default")], 2) : _vm._e()])
},staticRenderFns: []}
/***/ },
-/* 145 */
+/* 123 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _buttonGroup = __webpack_require__(124);
+
+ var _buttonGroup2 = _interopRequireDefault(_buttonGroup);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _buttonGroup2.default.install = function (Vue) {
+ Vue.component(_buttonGroup2.default.name, _buttonGroup2.default);
+ };
+
+ exports.default = _buttonGroup2.default;
+
+/***/ },
+/* 124 */
+/***/ function(module, exports, __webpack_require__) {
+
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(125),
+ /* template */
+ __webpack_require__(126),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
+
+ module.exports = Component.exports
+
+
+/***/ },
+/* 125 */
/***/ function(module, exports) {
'use strict';
exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+
+ /**
+ * button
+ * @module components/basic/menu
+ * @desc 用于按钮组
+ * @param {string} label - 名称
+ */
exports.default = {
- name: 'ElTableFooter',
+ name: 'ElButtonGroup'
+ };
- render: function render(h) {
- var _this = this;
+/***/ },
+/* 126 */
+/***/ function(module, exports) {
- var sums = [];
- 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',
- null,
- [this._l(this.columns, function (column) {
- return h(
- 'col',
- {
- attrs: {
- name: column.id,
- width: column.realWidth || column.width
- }
- },
- []
- );
- }), !this.fixed && this.layout.gutterWidth ? h(
- 'col',
- {
- attrs: { name: 'gutter', width: this.layout.scrollY ? this.layout.gutterWidth : '' }
- },
- []
- ) : '']
- ), h(
- 'tbody',
- null,
- [h(
- 'tr',
- null,
- [this._l(this.columns, function (column, cellIndex) {
- return h(
- 'td',
- {
- attrs: {
- colspan: column.colSpan,
- rowspan: column.rowSpan
- },
- 'class': [column.id, column.headerAlign, column.className || '', _this.isCellHidden(cellIndex, _this.columns) ? 'is-hidden' : '', !column.children ? 'is-leaf' : '', column.labelClassName] },
- [h(
- 'div',
- { 'class': ['cell', column.labelClassName] },
- [_this.summaryMethod ? _this.summaryMethod({ columns: _this.columns, data: _this.store.states.data })[cellIndex] : sums[cellIndex]]
- )]
- );
- }), !this.fixed && this.layout.gutterWidth ? h(
- 'td',
- { 'class': 'gutter', style: { width: this.layout.scrollY ? this.layout.gutterWidth + 'px' : '0' } },
- []
- ) : '']
- )]
- )]
- );
- },
-
-
- props: {
- fixed: String,
- store: {
- required: true
- },
- layout: {
- required: true
- },
- summaryMethod: Function,
- sumText: String,
- border: Boolean,
- defaultSort: {
- type: Object,
- default: function _default() {
- return {
- prop: '',
- order: ''
- };
- }
- }
- },
-
- computed: {
- isAllSelected: function isAllSelected() {
- return this.store.states.isAllSelected;
- },
- columnsCount: function columnsCount() {
- return this.store.states.columns.length;
- },
- leftFixedCount: function leftFixedCount() {
- return this.store.states.fixedColumns.length;
- },
- rightFixedCount: function rightFixedCount() {
- return this.store.states.rightFixedColumns.length;
- },
- columns: function columns() {
- return this.store.states.columns;
- }
- },
-
- methods: {
- isCellHidden: function isCellHidden(index, columns) {
- if (this.fixed === true || this.fixed === 'left') {
- return index >= this.leftFixedCount;
- } else if (this.fixed === 'right') {
- var before = 0;
- for (var i = 0; i < index; i++) {
- before += columns[i].colSpan;
- }
- return before < this.columnsCount - this.rightFixedCount;
- } else {
- return index < this.leftFixedCount || index >= this.columnsCount - this.rightFixedCount;
- }
- }
- }
- };
-
-/***/ },
-/* 146 */
-/***/ function(module, exports) {
-
- module.exports={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,
- 'el-table--hidden': _vm.isHidden,
- 'el-table--fluid-height': _vm.maxHeight,
- '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
- },
- on: {
- "mouseleave": function($event) {
- _vm.handleMouseLeave($event)
- }
- }
- }, [_c('div', {
- ref: "hiddenColumns",
- staticClass: "hidden-columns"
- }, [_vm._t("default")], 2), (_vm.showHeader) ? _c('div', {
- ref: "headerWrapper",
- staticClass: "el-table__header-wrapper"
- }, [_c('table-header', {
- style: ({
- width: _vm.layout.bodyWidth ? _vm.layout.bodyWidth + 'px' : ''
- }),
- attrs: {
- "store": _vm.store,
- "layout": _vm.layout,
- "border": _vm.border,
- "default-sort": _vm.defaultSort
- }
- })], 1) : _vm._e(), _c('div', {
- ref: "bodyWrapper",
- staticClass: "el-table__body-wrapper",
- style: ([_vm.bodyHeight])
- }, [_c('table-body', {
- style: ({
- width: _vm.bodyWidth
- }),
- attrs: {
- "context": _vm.context,
- "store": _vm.store,
- "stripe": _vm.stripe,
- "layout": _vm.layout,
- "row-class-name": _vm.rowClassName,
- "row-style": _vm.rowStyle,
- "highlight": _vm.highlightCurrentRow
- }
- }), (!_vm.data || _vm.data.length === 0) ? _c('div', {
- staticClass: "el-table__empty-block",
- style: ({
- width: _vm.bodyWidth
- })
- }, [_c('span', {
- staticClass: "el-table__empty-text"
- }, [_vm._t("empty", [_vm._v(_vm._s(_vm.emptyText || _vm.t('el.table.emptyText')))])], 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"
- }],
- ref: "footerWrapper",
- staticClass: "el-table__footer-wrapper"
- }, [_c('table-footer', {
- style: ({
- width: _vm.layout.bodyWidth ? _vm.layout.bodyWidth + 'px' : ''
- }),
- attrs: {
- "store": _vm.store,
- "layout": _vm.layout,
- "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', {
- 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', {
- style: ({
- width: _vm.layout.fixedWidth ? _vm.layout.fixedWidth + 'px' : ''
- }),
- attrs: {
- "fixed": "left",
- "border": _vm.border,
- "store": _vm.store,
- "layout": _vm.layout
- }
- })], 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.layout.fixedWidth ? _vm.layout.fixedWidth + 'px' : ''
- }),
- attrs: {
- "fixed": "left",
- "store": _vm.store,
- "stripe": _vm.stripe,
- "layout": _vm.layout,
- "highlight": _vm.highlightCurrentRow,
- "row-class-name": _vm.rowClassName,
- "row-style": _vm.rowStyle
- }
- })], 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.layout.fixedWidth ? _vm.layout.fixedWidth + 'px' : ''
- }),
- attrs: {
- "fixed": "left",
- "border": _vm.border,
- "sum-text": _vm.sumText || _vm.t('el.table.sumText'),
- "summary-method": _vm.summaryMethod,
- "store": _vm.store,
- "layout": _vm.layout
- }
- })], 1) : _vm._e()]) : _vm._e(), (_vm.rightFixedColumns.length > 0) ? _c('div', {
- 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 || 1)) + 'px' : ''
- },
- _vm.fixedHeight
- ])
- }, [(_vm.showHeader) ? _c('div', {
- ref: "rightFixedHeaderWrapper",
- staticClass: "el-table__fixed-header-wrapper"
- }, [_c('table-header', {
- style: ({
- width: _vm.layout.rightFixedWidth ? _vm.layout.rightFixedWidth + 'px' : ''
- }),
- attrs: {
- "fixed": "right",
- "border": _vm.border,
- "store": _vm.store,
- "layout": _vm.layout
- }
- })], 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.layout.rightFixedWidth ? _vm.layout.rightFixedWidth + 'px' : ''
- }),
- attrs: {
- "fixed": "right",
- "store": _vm.store,
- "stripe": _vm.stripe,
- "layout": _vm.layout,
- "row-class-name": _vm.rowClassName,
- "row-style": _vm.rowStyle,
- "highlight": _vm.highlightCurrentRow
- }
- })], 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.layout.rightFixedWidth ? _vm.layout.rightFixedWidth + 'px' : ''
- }),
- attrs: {
- "fixed": "right",
- "border": _vm.border,
- "sum-text": _vm.sumText || _vm.t('el.table.sumText'),
- "summary-method": _vm.summaryMethod,
- "store": _vm.store,
- "layout": _vm.layout
- }
- })], 1) : _vm._e()]) : _vm._e(), (_vm.rightFixedColumns.length > 0) ? _c('div', {
- 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"
- })])
- },staticRenderFns: []}
+ module.exports={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)
+ },staticRenderFns: []}
/***/ },
-/* 147 */
+/* 127 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _tableColumn = __webpack_require__(148);
+ var _table = __webpack_require__(128);
- var _tableColumn2 = _interopRequireDefault(_tableColumn);
+ var _table2 = _interopRequireDefault(_table);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _tableColumn2.default.install = function (Vue) {
- Vue.component(_tableColumn2.default.name, _tableColumn2.default);
+ _table2.default.install = function (Vue) {
+ Vue.component(_table2.default.name, _table2.default);
};
- exports.default = _tableColumn2.default;
+ exports.default = _table2.default;
/***/ },
-/* 148 */
+/* 128 */
+/***/ function(module, exports, __webpack_require__) {
+
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(129),
+ /* template */
+ __webpack_require__(146),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
+
+ module.exports = Component.exports
+
+
+/***/ },
+/* 129 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
@@ -44093,2032 +42509,2204 @@ module.exports =
var _checkbox2 = _interopRequireDefault(_checkbox);
- var _tag = __webpack_require__(109);
+ var _throttle = __webpack_require__(131);
- var _tag2 = _interopRequireDefault(_tag);
+ var _throttle2 = _interopRequireDefault(_throttle);
- var _merge = __webpack_require__(64);
+ var _debounce = __webpack_require__(69);
- var _merge2 = _interopRequireDefault(_merge);
+ var _debounce2 = _interopRequireDefault(_debounce);
- var _util = __webpack_require__(107);
+ var _resizeEvent = __webpack_require__(110);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _locale = __webpack_require__(10);
- function _objectDestructuringEmpty(obj) { if (obj == null) throw new TypeError("Cannot destructure undefined"); }
+ var _locale2 = _interopRequireDefault(_locale);
- var columnIdSeed = 1;
+ var _tableStore = __webpack_require__(132);
- var defaults = {
- 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 _tableStore2 = _interopRequireDefault(_tableStore);
- var forced = {
- selection: {
- renderHeader: function renderHeader(h) {
- return h(
- 'el-checkbox',
- {
- nativeOn: {
- 'click': this.toggleAllSelection
- },
- attrs: {
- value: this.isAllSelected }
- },
- []
- );
- },
- renderCell: function renderCell(h, _ref) {
- var row = _ref.row,
- column = _ref.column,
- store = _ref.store,
- $index = _ref.$index;
+ var _tableLayout = __webpack_require__(135);
- return h(
- 'el-checkbox',
- {
- 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, _ref2) {
- var column = _ref2.column;
+ var _tableLayout2 = _interopRequireDefault(_tableLayout);
- return column.label || '#';
- },
- renderCell: function renderCell(h, _ref3) {
- var $index = _ref3.$index;
+ var _tableBody = __webpack_require__(137);
- return h(
- 'div',
- null,
- [$index + 1]
- );
- },
- sortable: false
- },
- expand: {
- renderHeader: function renderHeader(h, _ref4) {
- _objectDestructuringEmpty(_ref4);
+ var _tableBody2 = _interopRequireDefault(_tableBody);
- return '';
- },
- renderCell: function renderCell(h, _ref5, proxy) {
- var row = _ref5.row,
- store = _ref5.store;
+ var _tableHeader = __webpack_require__(139);
- var expanded = store.states.expandRows.indexOf(row) > -1;
- return h(
- 'div',
- { 'class': 'el-table__expand-icon ' + (expanded ? 'el-table__expand-icon--expanded' : ''),
- on: {
- 'click': function click() {
- return proxy.handleExpandClick(row);
- }
- }
- },
- [h(
- 'i',
- { 'class': 'el-icon el-icon-arrow-right' },
- []
- )]
- );
- },
- sortable: false,
- resizable: false,
- className: 'el-table__expand-column'
- }
- };
+ var _tableHeader2 = _interopRequireDefault(_tableHeader);
- var getDefaultColumn = function getDefaultColumn(type, options) {
- var column = {};
+ var _tableFooter = __webpack_require__(145);
- (0, _merge2.default)(column, defaults[type || 'default']);
-
- for (var name in options) {
- if (options.hasOwnProperty(name)) {
- var value = options[name];
- if (typeof value !== 'undefined') {
- column[name] = value;
- }
- }
- }
-
- if (!column.minWidth) {
- column.minWidth = 80;
- }
-
- column.realWidth = column.width || column.minWidth;
+ var _tableFooter2 = _interopRequireDefault(_tableFooter);
- return column;
- };
+ var _util = __webpack_require__(134);
- var DEFAULT_RENDER_CELL = function DEFAULT_RENDER_CELL(h, _ref6) {
- var row = _ref6.row,
- column = _ref6.column;
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var property = column.property;
- var value = property && property.indexOf('.') === -1 ? row[property] : (0, _util.getValueByPath)(row, property);
- if (column && column.formatter) {
- return column.formatter(row, column, value);
- }
- return value;
- };
+ var tableIdSeed = 1; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
exports.default = {
- name: 'ElTableColumn',
+ name: 'ElTable',
+
+ mixins: [_locale2.default],
props: {
- type: {
- type: String,
- default: 'default'
- },
- label: String,
- className: String,
- labelClassName: String,
- property: String,
- prop: String,
- width: {},
- minWidth: {},
- renderHeader: Function,
- sortable: {
- type: [String, Boolean],
- default: false
+ data: {
+ type: Array,
+ default: function _default() {
+ return [];
+ }
},
- sortMethod: Function,
- resizable: {
+
+ width: [String, Number],
+
+ height: [String, Number],
+
+ maxHeight: [String, Number],
+
+ fit: {
type: Boolean,
default: true
},
+
+ stripe: Boolean,
+
+ border: Boolean,
+
+ rowKey: [String, Function],
+
context: {},
- 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: {
+
+ showHeader: {
type: Boolean,
default: true
- }
- },
+ },
- data: function data() {
- return {
- isSubColumn: false,
- columns: []
- };
- },
- beforeCreate: function beforeCreate() {
- this.row = {};
- this.column = {};
- this.$index = 0;
- },
+ showSummary: Boolean,
+ sumText: String,
- components: {
- ElCheckbox: _checkbox2.default,
- ElTag: _tag2.default
- },
+ summaryMethod: Function,
- computed: {
- owner: function owner() {
- var parent = this.$parent;
- while (parent && !parent.tableId) {
- parent = parent.$parent;
- }
- return parent;
- }
- },
+ rowClassName: [String, Function],
- created: function created() {
- var _this = this;
+ rowStyle: [Object, Function],
- this.customRender = this.$options.render;
- this.$options.render = function (h) {
- return h('div', _this.$slots.default);
- };
- this.columnId = (this.$parent.tableId || this.$parent.columnId + '_') + 'column_' + columnIdSeed++;
+ highlightCurrentRow: Boolean,
- var parent = this.$parent;
- var owner = this.owner;
- this.isSubColumn = owner !== parent;
+ currentRowKey: [String, Number],
- var type = this.type;
+ emptyText: String,
- var width = this.width;
- if (width !== undefined) {
- width = parseInt(width, 10);
- if (isNaN(width)) {
- width = null;
- }
- }
+ expandRowKeys: Array,
- var minWidth = this.minWidth;
- if (minWidth !== undefined) {
- minWidth = parseInt(minWidth, 10);
- if (isNaN(minWidth)) {
- minWidth = 80;
- }
- }
+ defaultExpandAll: Boolean,
- var isColumnGroup = false;
+ defaultSort: Object,
- var column = getDefaultColumn(type, {
- id: this.columnId,
- columnKey: this.columnKey,
- label: this.label,
- className: this.className,
- labelClassName: this.labelClassName,
- property: this.prop || this.property,
- type: type,
- renderCell: null,
- renderHeader: this.renderHeader,
- minWidth: minWidth,
- width: width,
- isColumnGroup: isColumnGroup,
- context: this.context,
- align: this.align ? 'is-' + this.align : null,
- headerAlign: this.headerAlign ? 'is-' + this.headerAlign : this.align ? 'is-' + this.align : null,
- sortable: this.sortable === '' ? true : this.sortable,
- sortMethod: this.sortMethod,
- resizable: this.resizable,
- showOverflowTooltip: this.showOverflowTooltip || this.showTooltipWhenOverflow,
- formatter: this.formatter,
- selectable: this.selectable,
- reserveSelection: this.reserveSelection,
- fixed: this.fixed === '' ? true : this.fixed,
- filterMethod: this.filterMethod,
- filters: this.filters,
- filterable: this.filters || this.filterMethod,
- filterMultiple: this.filterMultiple,
- filterOpened: false,
- filteredValue: this.filteredValue || [],
- filterPlacement: this.filterPlacement || ''
- });
+ tooltipEffect: String
+ },
- (0, _merge2.default)(column, forced[type] || {});
+ components: {
+ TableHeader: _tableHeader2.default,
+ TableFooter: _tableFooter2.default,
+ TableBody: _tableBody2.default,
+ ElCheckbox: _checkbox2.default
+ },
- this.columnConfig = column;
+ methods: {
+ setCurrentRow: function setCurrentRow(row) {
+ this.store.commit('setCurrentRow', row);
+ },
+ toggleRowSelection: function toggleRowSelection(row, selected) {
+ this.store.toggleRowSelection(row, selected);
+ this.store.updateAllSelected();
+ },
+ clearSelection: function clearSelection() {
+ this.store.clearSelection();
+ },
+ handleMouseLeave: function handleMouseLeave() {
+ this.store.commit('setHoverRow', null);
+ if (this.hoverState) this.hoverState = null;
+ },
+ updateScrollY: function updateScrollY() {
+ this.layout.updateScrollY();
+ },
+ bindEvents: function bindEvents() {
+ var _this = this;
- var renderCell = column.renderCell;
- var _self = this;
+ var _$refs = this.$refs,
+ headerWrapper = _$refs.headerWrapper,
+ footerWrapper = _$refs.footerWrapper;
- if (type === 'expand') {
- owner.renderExpanded = function (h, data) {
- return _self.$scopedSlots.default ? _self.$scopedSlots.default(data) : _self.$slots.default;
- };
+ var refs = this.$refs;
+ this.bodyWrapper.addEventListener('scroll', function () {
+ if (headerWrapper) headerWrapper.scrollLeft = this.scrollLeft;
+ if (footerWrapper) footerWrapper.scrollLeft = this.scrollLeft;
+ if (refs.fixedBodyWrapper) refs.fixedBodyWrapper.scrollTop = this.scrollTop;
+ if (refs.rightFixedBodyWrapper) refs.rightFixedBodyWrapper.scrollTop = this.scrollTop;
+ });
- column.renderCell = function (h, data) {
- return h(
- 'div',
- { 'class': 'cell' },
- [renderCell(h, data, this._renderProxy)]
- );
- };
+ var scrollBodyWrapper = function scrollBodyWrapper(event) {
+ var deltaX = event.deltaX,
+ deltaY = event.deltaY;
- return;
- }
- column.renderCell = function (h, data) {
- // 未来版本移除
- if (_self.$vnode.data.inlineTemplate) {
- renderCell = function renderCell() {
- data._self = _self.context || data._self;
- if (Object.prototype.toString.call(data._self) === '[object Object]') {
- for (var prop in data._self) {
- if (!data.hasOwnProperty(prop)) {
- data[prop] = data._self[prop];
- }
- }
- }
- // 静态内容会缓存到 _staticTrees 内,不改的话获取的静态数据就不是内部 context
- data._staticTrees = _self._staticTrees;
- data.$options.staticRenderFns = _self.$options.staticRenderFns;
- return _self.customRender.call(data);
- };
- } else if (_self.$scopedSlots.default) {
- renderCell = function renderCell() {
- return _self.$scopedSlots.default(data);
- };
+ if (Math.abs(deltaX) < Math.abs(deltaY)) return;
+
+ if (deltaX > 0) {
+ _this.bodyWrapper.scrollLeft += 10;
+ } else if (deltaX < 0) {
+ _this.bodyWrapper.scrollLeft -= 10;
+ }
+ };
+ if (headerWrapper) {
+ (0, _util.mousewheel)(headerWrapper, (0, _throttle2.default)(16, scrollBodyWrapper));
+ }
+ if (footerWrapper) {
+ (0, _util.mousewheel)(footerWrapper, (0, _throttle2.default)(16, scrollBodyWrapper));
}
- if (!renderCell) {
- renderCell = DEFAULT_RENDER_CELL;
+ if (this.fit) {
+ this.windowResizeListener = (0, _throttle2.default)(50, function () {
+ if (_this.$ready) _this.doLayout();
+ });
+ (0, _resizeEvent.addResizeListener)(this.$el, this.windowResizeListener);
}
+ },
+ doLayout: function doLayout() {
+ var _this2 = this;
- return _self.showOverflowTooltip || _self.showTooltipWhenOverflow ? h(
- 'div',
- { 'class': 'cell el-tooltip', style: 'width:' + (data.column.realWidth || data.column.width) + 'px' },
- [renderCell(h, data)]
- ) : h(
- 'div',
- { 'class': 'cell' },
- [renderCell(h, data)]
- );
- };
+ this.store.updateColumns();
+ this.layout.update();
+ this.updateScrollY();
+ this.$nextTick(function () {
+ if (_this2.height) {
+ _this2.layout.setHeight(_this2.height);
+ } else if (_this2.maxHeight) {
+ _this2.layout.setMaxHeight(_this2.maxHeight);
+ } else if (_this2.shouldUpdateHeight) {
+ _this2.layout.updateHeight();
+ }
+ if (_this2.$el) {
+ _this2.isHidden = _this2.$el.clientWidth === 0;
+ }
+ });
+ }
},
- destroyed: function destroyed() {
- if (!this.$parent) return;
- this.owner.store.commit('removeColumn', this.columnConfig);
+
+ created: function created() {
+ var _this3 = this;
+
+ this.tableId = 'el-table_' + tableIdSeed + '_';
+ this.debouncedLayout = (0, _debounce2.default)(50, function () {
+ return _this3.doLayout();
+ });
},
- watch: {
- label: function label(newVal) {
- if (this.columnConfig) {
- this.columnConfig.label = newVal;
- }
+ computed: {
+ bodyWrapper: function bodyWrapper() {
+ return this.$refs.bodyWrapper;
},
- prop: function prop(newVal) {
- if (this.columnConfig) {
- this.columnConfig.property = newVal;
- }
+ shouldUpdateHeight: function shouldUpdateHeight() {
+ return typeof this.height === 'number' || this.fixedColumns.length > 0 || this.rightFixedColumns.length > 0;
},
- property: function property(newVal) {
- if (this.columnConfig) {
- this.columnConfig.property = newVal;
- }
+ selection: function selection() {
+ return this.store.states.selection;
},
- filters: function filters(newVal) {
- if (this.columnConfig) {
- this.columnConfig.filters = newVal;
- }
+ columns: function columns() {
+ return this.store.states.columns;
},
- filterMultiple: function filterMultiple(newVal) {
- if (this.columnConfig) {
- this.columnConfig.filterMultiple = newVal;
- }
+ tableData: function tableData() {
+ return this.store.states.data;
},
- align: function align(newVal) {
- if (this.columnConfig) {
- this.columnConfig.align = newVal ? 'is-' + newVal : null;
-
- if (!this.headerAlign) {
- this.columnConfig.headerAlign = newVal ? 'is-' + newVal : null;
- }
- }
+ fixedColumns: function fixedColumns() {
+ return this.store.states.fixedColumns;
},
- headerAlign: function headerAlign(newVal) {
- if (this.columnConfig) {
- this.columnConfig.headerAlign = 'is-' + (newVal ? newVal : this.align);
- }
+ rightFixedColumns: function rightFixedColumns() {
+ return this.store.states.rightFixedColumns;
},
- width: function width(newVal) {
- if (this.columnConfig) {
- this.columnConfig.width = newVal;
- this.owner.store.scheduleLayout();
+ bodyHeight: function bodyHeight() {
+ var style = {};
+
+ if (this.height) {
+ style = {
+ height: this.layout.bodyHeight ? this.layout.bodyHeight + 'px' : ''
+ };
+ } else if (this.maxHeight) {
+ style = {
+ 'max-height': (this.showHeader ? this.maxHeight - this.layout.headerHeight - this.layout.footerHeight : this.maxHeight - this.layout.footerHeight) + 'px'
+ };
}
+
+ return style;
},
- minWidth: function minWidth(newVal) {
- if (this.columnConfig) {
- this.columnConfig.minWidth = newVal;
- this.owner.store.scheduleLayout();
+ bodyWidth: function bodyWidth() {
+ var _layout = this.layout,
+ bodyWidth = _layout.bodyWidth,
+ scrollY = _layout.scrollY,
+ gutterWidth = _layout.gutterWidth;
+
+ return bodyWidth ? bodyWidth - (scrollY ? gutterWidth : 0) + 'px' : '';
+ },
+ fixedBodyHeight: function fixedBodyHeight() {
+ var style = {};
+
+ if (this.height) {
+ style = {
+ height: this.layout.fixedBodyHeight ? this.layout.fixedBodyHeight + 'px' : ''
+ };
+ } else if (this.maxHeight) {
+ var maxHeight = this.layout.scrollX ? this.maxHeight - this.layout.gutterWidth : this.maxHeight;
+
+ if (this.showHeader) {
+ maxHeight -= this.layout.headerHeight;
+ }
+
+ style = {
+ 'max-height': maxHeight + 'px'
+ };
}
+
+ return style;
},
- fixed: function fixed(newVal) {
- if (this.columnConfig) {
- this.columnConfig.fixed = newVal;
- this.owner.store.scheduleLayout();
+ fixedHeight: function fixedHeight() {
+ var style = {};
+
+ if (this.maxHeight) {
+ style = {
+ bottom: this.layout.scrollX && this.data.length ? this.layout.gutterWidth + 'px' : ''
+ };
+ } else {
+ style = {
+ height: this.layout.viewportHeight ? this.layout.viewportHeight + 'px' : ''
+ };
}
+
+ return style;
+ }
+ },
+
+ watch: {
+ height: function height(value) {
+ this.layout.setHeight(value);
},
- sortable: function sortable(newVal) {
- if (this.columnConfig) {
- this.columnConfig.sortable = newVal;
+ currentRowKey: function currentRowKey(newVal) {
+ this.store.setCurrentRowKey(newVal);
+ },
+
+
+ data: {
+ immediate: true,
+ handler: function handler(val) {
+ this.store.commit('setData', val);
+ if (this.$ready) this.doLayout();
}
+ },
+
+ expandRowKeys: function expandRowKeys(newVal) {
+ this.store.setExpandRowKeys(newVal);
}
},
+ destroyed: function destroyed() {
+ if (this.windowResizeListener) (0, _resizeEvent.removeResizeListener)(this.$el, this.windowResizeListener);
+ },
mounted: function mounted() {
- var owner = this.owner;
- var parent = this.$parent;
- var columnIndex = void 0;
+ var _this4 = this;
- if (!this.isSubColumn) {
- columnIndex = [].indexOf.call(parent.$refs.hiddenColumns.children, this.$el);
- } else {
- columnIndex = [].indexOf.call(parent.$el.children, this.$el);
- }
+ this.bindEvents();
+ this.doLayout();
- owner.store.commit('insertColumn', this.columnConfig, columnIndex, this.isSubColumn ? parent.columnConfig : null);
+ // init filters
+ this.store.states.columns.forEach(function (column) {
+ if (column.filteredValue && column.filteredValue.length) {
+ _this4.store.commit('filterChange', {
+ column: column,
+ values: column.filteredValue,
+ silent: true
+ });
+ }
+ });
+
+ this.$ready = true;
+ },
+ data: function data() {
+ var store = new _tableStore2.default(this, {
+ rowKey: this.rowKey,
+ defaultExpandAll: this.defaultExpandAll
+ });
+ var layout = new _tableLayout2.default({
+ store: store,
+ table: this,
+ fit: this.fit,
+ showHeader: this.showHeader
+ });
+ return {
+ store: store,
+ layout: layout,
+ isHidden: false,
+ renderExpanded: null,
+ resizeProxyVisible: false
+ };
}
};
/***/ },
-/* 149 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _datePicker = __webpack_require__(150);
-
- var _datePicker2 = _interopRequireDefault(_datePicker);
+/* 130 */
+/***/ function(module, exports) {
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ module.exports = __webpack_require__(52);
- /* istanbul ignore next */
- _datePicker2.default.install = function install(Vue) {
- Vue.component(_datePicker2.default.name, _datePicker2.default);
- };
+/***/ },
+/* 131 */
+/***/ function(module, exports) {
- exports.default = _datePicker2.default;
+ module.exports = __webpack_require__(25);
/***/ },
-/* 150 */
+/* 132 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _picker = __webpack_require__(151);
-
- var _picker2 = _interopRequireDefault(_picker);
+ var _vue = __webpack_require__(133);
- var _date = __webpack_require__(156);
+ var _vue2 = _interopRequireDefault(_vue);
- var _date2 = _interopRequireDefault(_date);
+ var _debounce = __webpack_require__(69);
- var _dateRange = __webpack_require__(174);
+ var _debounce2 = _interopRequireDefault(_debounce);
- var _dateRange2 = _interopRequireDefault(_dateRange);
+ var _util = __webpack_require__(134);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var getPanel = function getPanel(type) {
- if (type === 'daterange' || type === 'datetimerange') {
- return _dateRange2.default;
+ var sortData = function sortData(data, states) {
+ var sortingColumn = states.sortingColumn;
+ if (!sortingColumn || typeof sortingColumn.sortable === 'string') {
+ return data;
}
- return _date2.default;
+ return (0, _util.orderBy)(data, states.sortProp, states.sortOrder, sortingColumn.sortMethod);
};
- exports.default = {
- mixins: [_picker2.default],
-
- name: 'ElDatePicker',
+ var getKeysMap = function getKeysMap(array, rowKey) {
+ var arrayMap = {};
+ (array || []).forEach(function (row, index) {
+ arrayMap[(0, _util.getRowIdentity)(row, rowKey)] = { row: row, index: index };
+ });
+ return arrayMap;
+ };
- props: {
- type: {
- type: String,
- default: 'date'
+ var toggleRowSelection = function toggleRowSelection(states, row, selected) {
+ var changed = false;
+ var selection = states.selection;
+ var index = selection.indexOf(row);
+ if (typeof selected === 'undefined') {
+ if (index === -1) {
+ selection.push(row);
+ changed = true;
+ } else {
+ selection.splice(index, 1);
+ changed = true;
}
- },
-
- watch: {
- type: function type(_type) {
- if (this.picker) {
- this.unmountPicker();
- this.panel = getPanel(_type);
- this.mountPicker();
- } else {
- this.panel = getPanel(_type);
- }
+ } else {
+ if (selected && index === -1) {
+ selection.push(row);
+ changed = true;
+ } else if (!selected && index > -1) {
+ selection.splice(index, 1);
+ changed = true;
}
- },
-
- created: function created() {
- this.panel = getPanel(this.type);
}
+
+ return changed;
};
-/***/ },
-/* 151 */
-/***/ function(module, exports, __webpack_require__) {
+ var TableStore = function TableStore(table) {
+ var initialState = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(152),
- /* template */
- __webpack_require__(155),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ if (!table) {
+ throw new Error('Table is required.');
+ }
+ this.table = table;
- module.exports = Component.exports
+ this.states = {
+ rowKey: null,
+ _columns: [],
+ originColumns: [],
+ columns: [],
+ fixedColumns: [],
+ rightFixedColumns: [],
+ isComplex: false,
+ _data: null,
+ filteredData: null,
+ data: null,
+ sortingColumn: null,
+ sortProp: null,
+ sortOrder: null,
+ isAllSelected: false,
+ selection: [],
+ reserveSelection: false,
+ selectable: null,
+ currentRow: null,
+ hoverRow: null,
+ filters: {},
+ expandRows: [],
+ defaultExpandAll: false
+ };
+ for (var prop in initialState) {
+ if (initialState.hasOwnProperty(prop) && this.states.hasOwnProperty(prop)) {
+ this.states[prop] = initialState[prop];
+ }
+ }
+ };
-/***/ },
-/* 152 */
-/***/ function(module, exports, __webpack_require__) {
+ TableStore.prototype.mutations = {
+ setData: function setData(states, data) {
+ var _this = this;
- 'use strict';
+ var dataInstanceChanged = states._data !== data;
+ states._data = data;
+ states.data = sortData(data || [], states);
- exports.__esModule = true;
+ // states.data.forEach((item) => {
+ // if (!item.$extra) {
+ // Object.defineProperty(item, '$extra', {
+ // value: {},
+ // enumerable: false
+ // });
+ // }
+ // });
- var _vue = __webpack_require__(133);
+ this.updateCurrentRow();
- var _vue2 = _interopRequireDefault(_vue);
+ if (!states.reserveSelection) {
+ if (dataInstanceChanged) {
+ this.clearSelection();
+ } else {
+ this.cleanSelection();
+ }
+ this.updateAllSelected();
+ } else {
+ (function () {
+ var rowKey = states.rowKey;
+ if (rowKey) {
+ (function () {
+ var selection = states.selection;
+ var selectedMap = getKeysMap(selection, rowKey);
- var _clickoutside = __webpack_require__(21);
+ states.data.forEach(function (row) {
+ var rowId = (0, _util.getRowIdentity)(row, rowKey);
+ var rowInfo = selectedMap[rowId];
+ if (rowInfo) {
+ selection[rowInfo.index] = row;
+ }
+ });
- var _clickoutside2 = _interopRequireDefault(_clickoutside);
+ _this.updateAllSelected();
+ })();
+ } else {
+ console.warn('WARN: rowKey is required when reserve-selection is enabled.');
+ }
+ })();
+ }
- var _util = __webpack_require__(153);
+ var defaultExpandAll = states.defaultExpandAll;
+ if (defaultExpandAll) {
+ this.states.expandRows = (states.data || []).slice(0);
+ }
- var _vuePopper = __webpack_require__(24);
+ _vue2.default.nextTick(function () {
+ return _this.table.updateScrollY();
+ });
+ },
+ changeSortCondition: function changeSortCondition(states) {
+ var _this2 = this;
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
+ states.data = sortData(states.filteredData || states._data || [], states);
- var _emitter = __webpack_require__(15);
+ this.table.$emit('sort-change', {
+ column: this.states.sortingColumn,
+ prop: this.states.sortProp,
+ order: this.states.sortOrder
+ });
- var _emitter2 = _interopRequireDefault(_emitter);
+ _vue2.default.nextTick(function () {
+ return _this2.table.updateScrollY();
+ });
+ },
+ filterChange: function filterChange(states, options) {
+ var _this3 = this;
- var _input = __webpack_require__(20);
+ var column = options.column,
+ values = options.values,
+ silent = options.silent;
- var _input2 = _interopRequireDefault(_input);
+ if (values && !Array.isArray(values)) {
+ values = [values];
+ }
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var prop = column.property;
+ var filters = {};
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ if (prop) {
+ states.filters[column.id] = values;
+ filters[column.columnKey || column.id] = values;
+ }
- var NewPopper = {
- props: {
- appendToBody: _vuePopper2.default.props.appendToBody,
- offset: _vuePopper2.default.props.offset,
- boundariesPadding: _vuePopper2.default.props.boundariesPadding
- },
- methods: _vuePopper2.default.methods,
- data: _vuePopper2.default.data,
- beforeDestroy: _vuePopper2.default.beforeDestroy
- };
+ var data = states._data;
- 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',
- datetimerange: 'yyyy-MM-dd HH:mm:ss',
- year: 'yyyy'
- };
- var HAVE_TRIGGER_TYPES = ['date', 'datetime', 'time', 'time-select', 'week', 'month', 'year', 'daterange', 'timerange', 'datetimerange'];
- var DATE_FORMATTER = function DATE_FORMATTER(value, format) {
- return (0, _util.formatDate)(value, format);
- };
- var DATE_PARSER = function DATE_PARSER(text, format) {
- return (0, _util.parseDate)(text, format);
- };
- var RANGE_FORMATTER = function RANGE_FORMATTER(value, format, separator) {
- if (Array.isArray(value) && value.length === 2) {
- var start = value[0];
- var end = value[1];
+ Object.keys(states.filters).forEach(function (columnId) {
+ var values = states.filters[columnId];
+ if (!values || values.length === 0) return;
+ var column = (0, _util.getColumnById)(_this3.states, columnId);
+ if (column && column.filterMethod) {
+ data = data.filter(function (row) {
+ return values.some(function (value) {
+ return column.filterMethod.call(null, value, row);
+ });
+ });
+ }
+ });
- if (start && end) {
- return (0, _util.formatDate)(start, format) + separator + (0, _util.formatDate)(end, format);
- }
- }
- return '';
- };
- var RANGE_PARSER = function RANGE_PARSER(text, format, separator) {
- var array = text.split(separator);
- if (array.length === 2) {
- var range1 = array[0];
- var range2 = array[1];
+ states.filteredData = data;
+ states.data = sortData(data, states);
- return [(0, _util.parseDate)(range1, format), (0, _util.parseDate)(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;
+ if (!silent) {
+ this.table.$emit('filter-change', filters);
}
+
+ _vue2.default.nextTick(function () {
+ return _this3.table.updateScrollY();
+ });
},
- week: {
- formatter: function formatter(value, format) {
- var date = (0, _util.formatDate)(value, format);
- var week = (0, _util.getWeekNumber)(value);
+ insertColumn: function insertColumn(states, column, index, parent) {
+ var array = states._columns;
+ if (parent) {
+ array = parent.children;
+ if (!array) array = parent.children = [];
+ }
- date = /WW/.test(date) ? date.replace(/WW/, week < 10 ? '0' + week : week) : date.replace(/W/, week);
- return date;
- },
- parser: function parser(text) {
- var array = (text || '').split('w');
- if (array.length === 2) {
- var year = Number(array[0]);
- var month = Number(array[1]);
+ if (typeof index !== 'undefined') {
+ array.splice(index, 0, column);
+ } else {
+ array.push(column);
+ }
- if (!isNaN(year) && !isNaN(month) && month < 54) {
- return text;
- }
- }
- return null;
+ if (column.type === 'selection') {
+ states.selectable = column.selectable;
+ states.reserveSelection = column.reserveSelection;
}
+
+ this.updateColumns(); // hack for dynamics insert column
+ this.scheduleLayout();
},
- date: {
- formatter: DATE_FORMATTER,
- parser: DATE_PARSER
- },
- datetime: {
- formatter: DATE_FORMATTER,
- parser: DATE_PARSER
- },
- daterange: {
- formatter: RANGE_FORMATTER,
- parser: RANGE_PARSER
- },
- datetimerange: {
- formatter: RANGE_FORMATTER,
- parser: RANGE_PARSER
- },
- timerange: {
- formatter: RANGE_FORMATTER,
- parser: RANGE_PARSER
- },
- time: {
- formatter: DATE_FORMATTER,
- parser: DATE_PARSER
- },
- month: {
- formatter: DATE_FORMATTER,
- parser: DATE_PARSER
+ removeColumn: function removeColumn(states, column) {
+ var _columns = states._columns;
+ if (_columns) {
+ _columns.splice(_columns.indexOf(column), 1);
+ }
+
+ this.updateColumns(); // hack for dynamics remove column
+ this.scheduleLayout();
},
- year: {
- formatter: DATE_FORMATTER,
- parser: DATE_PARSER
+ setHoverRow: function setHoverRow(states, row) {
+ states.hoverRow = row;
},
- number: {
- formatter: function formatter(value) {
- if (!value) return '';
- return '' + value;
- },
- parser: function parser(text) {
- var result = Number(text);
+ setCurrentRow: function setCurrentRow(states, row) {
+ var oldCurrentRow = states.currentRow;
+ states.currentRow = row;
- if (!isNaN(text)) {
- return result;
- } else {
- return null;
- }
+ if (oldCurrentRow !== row) {
+ this.table.$emit('current-change', row, oldCurrentRow);
}
- }
- };
- var PLACEMENT_MAP = {
- left: 'bottom-start',
- center: 'bottom',
- right: 'bottom-end'
- };
-
- // only considers date-picker's value: Date or [Date, Date]
- var valueEquals = function valueEquals(a, b) {
- var aIsArray = a instanceof Array;
- var bIsArray = b instanceof Array;
- if (aIsArray && bIsArray) {
- return new Date(a[0]).getTime() === new Date(b[0]).getTime() && new Date(a[1]).getTime() === new Date(b[1]).getTime();
- }
- if (!aIsArray && !bIsArray) {
- return new Date(a).getTime() === new Date(b).getTime();
- }
- return false;
- };
-
- exports.default = {
- mixins: [_emitter2.default, NewPopper],
-
- props: {
- size: String,
- format: String,
- readonly: Boolean,
- placeholder: String,
- disabled: Boolean,
- clearable: {
- type: Boolean,
- default: true
- },
- popperClass: String,
- editable: {
- type: Boolean,
- default: true
- },
- align: {
- type: String,
- default: 'left'
- },
- value: {},
- defaultValue: {},
- rangeSeparator: {
- default: ' - '
- },
- pickerOptions: {}
},
+ rowSelectedChanged: function rowSelectedChanged(states, row) {
+ var changed = toggleRowSelection(states, row);
+ var selection = states.selection;
- components: { ElInput: _input2.default },
-
- directives: { Clickoutside: _clickoutside2.default },
+ if (changed) {
+ var table = this.table;
+ table.$emit('selection-change', selection);
+ table.$emit('select', selection, row);
+ }
- data: function data() {
- return {
- pickerVisible: false,
- showClose: false,
- currentValue: '',
- unwatchPickerOptions: null
- };
+ this.updateAllSelected();
},
- watch: {
- pickerVisible: function pickerVisible(val) {
- if (!val) this.dispatch('ElFormItem', 'el.form.blur');
- if (this.readonly || this.disabled) return;
- val ? this.showPicker() : this.hidePicker();
- },
- currentValue: function currentValue(val) {
- if (val) return;
- if (this.picker && typeof this.picker.handleClear === 'function') {
- this.picker.handleClear();
+ toggleRowExpanded: function toggleRowExpanded(states, row, expanded) {
+ var expandRows = states.expandRows;
+ if (typeof expanded !== 'undefined') {
+ var index = expandRows.indexOf(row);
+ if (expanded) {
+ if (index === -1) expandRows.push(row);
} else {
- this.$emit('input');
+ if (index !== -1) expandRows.splice(index, 1);
}
- },
-
- value: {
- immediate: true,
- handler: function handler(val) {
- this.currentValue = (0, _util.isDate)(val) ? new Date(val) : val;
+ } else {
+ var _index = expandRows.indexOf(row);
+ if (_index === -1) {
+ expandRows.push(row);
+ } else {
+ expandRows.splice(_index, 1);
}
- },
- displayValue: function displayValue(val) {
- this.$emit('change', val);
- this.dispatch('ElFormItem', 'el.form.change');
}
+ this.table.$emit('expand', row, expandRows.indexOf(row) !== -1);
},
- computed: {
- reference: function reference() {
- return this.$refs.reference.$el;
- },
- refInput: function refInput() {
- if (this.reference) return this.reference.querySelector('input');
- return {};
- },
- valueIsEmpty: function valueIsEmpty() {
- var val = this.currentValue;
- if (Array.isArray(val)) {
- for (var i = 0, len = val.length; i < len; i++) {
- if (val[i]) {
- return false;
- }
+ toggleAllSelection: (0, _debounce2.default)(10, function (states) {
+ var data = states.data || [];
+ var value = !states.isAllSelected;
+ var selection = this.states.selection;
+ var selectionChanged = false;
+
+ data.forEach(function (item, index) {
+ if (states.selectable) {
+ if (states.selectable.call(null, item, index) && toggleRowSelection(states, item, value)) {
+ selectionChanged = true;
}
} else {
- if (val) {
- return false;
+ if (toggleRowSelection(states, item, value)) {
+ selectionChanged = true;
}
}
- return true;
- },
- triggerClass: function triggerClass() {
- return 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';
- }
+ });
- return 'day';
- },
- haveTrigger: function haveTrigger() {
- if (typeof this.showTrigger !== 'undefined') {
- return this.showTrigger;
- }
- return HAVE_TRIGGER_TYPES.indexOf(this.type) !== -1;
- },
+ var table = this.table;
+ if (selectionChanged) {
+ table.$emit('selection-change', selection);
+ }
+ table.$emit('select-all', selection);
+ states.isAllSelected = value;
+ })
+ };
+ 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;
+ };
- displayValue: {
- get: function get() {
- var value = this.currentValue;
- if (!value) return;
- var formatter = (TYPE_VALUE_RESOLVER_MAP[this.type] || TYPE_VALUE_RESOLVER_MAP['default']).formatter;
- var format = DEFAULT_FORMATS[this.type];
+ TableStore.prototype.updateColumns = function () {
+ 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';
+ });
- return formatter(value, this.format || format, this.rangeSeparator);
- },
- set: function set(value) {
- if (value) {
- var type = this.type;
- var parser = (TYPE_VALUE_RESOLVER_MAP[type] || TYPE_VALUE_RESOLVER_MAP['default']).parser;
- var parsedValue = parser(value, this.format || DEFAULT_FORMATS[type], this.rangeSeparator);
+ if (states.fixedColumns.length > 0 && _columns[0] && _columns[0].type === 'selection' && !_columns[0].fixed) {
+ _columns[0].fixed = true;
+ states.fixedColumns.unshift(_columns[0]);
+ }
+ states.originColumns = [].concat(states.fixedColumns).concat(_columns.filter(function (column) {
+ return !column.fixed;
+ })).concat(states.rightFixedColumns);
+ states.columns = doFlattenColumns(states.originColumns);
+ states.isComplex = states.fixedColumns.length > 0 || states.rightFixedColumns.length > 0;
+ };
- if (parsedValue && this.picker) {
- this.picker.value = parsedValue;
- }
- } else {
- this.$emit('input', value);
- this.picker.value = value;
- }
- this.$forceUpdate();
- }
+ TableStore.prototype.isSelected = function (row) {
+ return (this.states.selection || []).indexOf(row) > -1;
+ };
+
+ TableStore.prototype.clearSelection = function () {
+ var states = this.states;
+ states.isAllSelected = false;
+ var oldSelection = states.selection;
+ states.selection = [];
+ if (oldSelection.length > 0) {
+ this.table.$emit('selection-change', states.selection);
+ }
+ };
+
+ TableStore.prototype.setExpandRowKeys = function (rowKeys) {
+ var expandRows = [];
+ var data = this.states.data;
+ var rowKey = this.states.rowKey;
+ if (!rowKey) throw new Error('[Table] prop row-key should not be empty.');
+ var keysMap = getKeysMap(data, rowKey);
+ rowKeys.forEach(function (key) {
+ var info = keysMap[key];
+ if (info) {
+ expandRows.push(info.row);
}
- },
+ });
- created: function created() {
- // vue-popper
- this.popperOptions = {
- boundariesPadding: 0,
- gpuAcceleration: false
- };
- this.placement = PLACEMENT_MAP[this.align] || PLACEMENT_MAP.left;
- },
+ this.states.expandRows = expandRows;
+ };
+ TableStore.prototype.toggleRowSelection = function (row, selected) {
+ var changed = toggleRowSelection(this.states, row, selected);
+ if (changed) {
+ this.table.$emit('selection-change', this.states.selection);
+ }
+ };
- methods: {
- handleMouseEnterIcon: function handleMouseEnterIcon() {
- if (this.readonly || this.disabled) return;
- if (!this.valueIsEmpty && this.clearable) {
- this.showClose = true;
- }
- },
- handleClickIcon: function handleClickIcon() {
- if (this.readonly || this.disabled) return;
- if (this.showClose) {
- this.currentValue = this.$options.defaultValue || '';
- this.showClose = false;
- } else {
- this.pickerVisible = !this.pickerVisible;
- }
- },
- dateChanged: function dateChanged(dateA, dateB) {
- if (Array.isArray(dateA)) {
- var len = dateA.length;
- if (!dateB) return true;
- while (len--) {
- if (!(0, _util.equalDate)(dateA[len], dateB[len])) return true;
- }
- } else {
- if (!(0, _util.equalDate)(dateA, dateB)) return true;
+ TableStore.prototype.cleanSelection = function () {
+ var selection = this.states.selection || [];
+ var data = this.states.data;
+ var rowKey = this.states.rowKey;
+ 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;
+ });
+ }
- return false;
- },
- handleClose: function handleClose() {
- this.pickerVisible = false;
- },
- handleFocus: function handleFocus() {
- var type = this.type;
+ deleted.forEach(function (deletedItem) {
+ selection.splice(selection.indexOf(deletedItem), 1);
+ });
- if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) {
- this.pickerVisible = true;
- }
- this.$emit('focus', this);
- },
- handleBlur: function handleBlur() {
- this.$emit('blur', this);
- },
- handleKeydown: function handleKeydown(event) {
- var keyCode = event.keyCode;
+ if (deleted.length) {
+ this.table.$emit('selection-change', selection);
+ }
+ };
- // TAB or ESC
- if (keyCode === 9 || keyCode === 27) {
- this.pickerVisible = false;
- event.stopPropagation();
- }
- },
- hidePicker: function hidePicker() {
- if (this.picker) {
- this.picker.resetView && this.picker.resetView();
- this.pickerVisible = this.picker.visible = false;
- this.destroyPopper();
- }
- },
- showPicker: function showPicker() {
- var _this = this;
+ TableStore.prototype.updateAllSelected = function () {
+ var states = this.states;
+ var selection = states.selection,
+ rowKey = states.rowKey,
+ selectable = states.selectable,
+ data = states.data;
- if (this.$isServer) return;
- if (!this.picker) {
- this.mountPicker();
- }
- this.pickerVisible = this.picker.visible = true;
+ if (!data || data.length === 0) {
+ states.isAllSelected = false;
+ return;
+ }
- this.updatePopper();
+ var selectedMap = void 0;
+ if (rowKey) {
+ selectedMap = getKeysMap(states.selection, rowKey);
+ }
- if (this.currentValue instanceof Date) {
- this.picker.date = new Date(this.currentValue.getTime());
+ var isSelected = function isSelected(row) {
+ if (selectedMap) {
+ return !!selectedMap[(0, _util.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];
+ if (selectable) {
+ var isRowSelectable = selectable.call(null, item, i);
+ if (isRowSelectable) {
+ if (!isSelected(item)) {
+ isAllSelected = false;
+ break;
+ } else {
+ selectedCount++;
+ }
+ }
+ } else {
+ if (!isSelected(item)) {
+ isAllSelected = false;
+ break;
} else {
- this.picker.value = this.currentValue;
+ selectedCount++;
}
- this.picker.resetView && this.picker.resetView();
+ }
+ }
- this.$nextTick(function () {
- _this.picker.ajustScrollTop && _this.picker.ajustScrollTop();
- });
- },
- mountPicker: function mountPicker() {
- var _this2 = this;
+ if (selectedCount === 0) isAllSelected = false;
- this.panel.defaultValue = this.defaultValue || this.currentValue;
- this.picker = new _vue2.default(this.panel).$mount();
- 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;
- if (this.format) {
- this.picker.format = this.format;
- }
+ states.isAllSelected = isAllSelected;
+ };
- var updateOptions = function updateOptions() {
- var options = _this2.pickerOptions;
+ TableStore.prototype.scheduleLayout = function () {
+ this.table.debouncedLayout();
+ };
- if (options && options.selectableRange) {
- (function () {
- var ranges = options.selectableRange;
- var parser = TYPE_VALUE_RESOLVER_MAP.datetimerange.parser;
- var format = DEFAULT_FORMATS.timerange;
+ TableStore.prototype.setCurrentRowKey = function (key) {
+ var states = this.states;
+ var rowKey = states.rowKey;
+ if (!rowKey) throw new Error('[Table] row-key should not be empty.');
+ var data = states.data || [];
+ var keysMap = getKeysMap(data, rowKey);
+ var info = keysMap[key];
+ if (info) {
+ states.currentRow = info.row;
+ }
+ };
- ranges = Array.isArray(ranges) ? ranges : [ranges];
- _this2.picker.selectableRange = ranges.map(function (range) {
- return parser(range, format, _this2.rangeSeparator);
- });
- })();
- }
+ TableStore.prototype.updateCurrentRow = function () {
+ var states = this.states;
+ var table = this.table;
+ var data = states.data || [];
+ var oldCurrentRow = states.currentRow;
- for (var option in options) {
- if (options.hasOwnProperty(option) &&
- // 忽略 time-picker 的该配置项
- option !== 'selectableRange') {
- _this2.picker[option] = options[option];
- }
- }
- };
- 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;
+ if (data.indexOf(oldCurrentRow) === -1) {
+ states.currentRow = null;
- // do not emit if values are same
- if (!valueEquals(_this2.value, date)) {
- _this2.$emit('input', date);
- }
- _this2.pickerVisible = _this2.picker.visible = visible;
- _this2.picker.resetView && _this2.picker.resetView();
- });
+ if (states.currentRow !== oldCurrentRow) {
+ table.$emit('current-change', null, oldCurrentRow);
+ }
+ }
+ };
- this.picker.$on('select-range', function (start, end) {
- _this2.refInput.setSelectionRange(start, end);
- _this2.refInput.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);
- }
+ TableStore.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);
}
};
+ exports.default = TableStore;
+
/***/ },
-/* 153 */
+/* 133 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(3);
+
+/***/ },
+/* 134 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- exports.limitRange = exports.getRangeHours = exports.nextMonth = exports.prevMonth = exports.getWeekNumber = exports.getStartDateOfMonth = exports.DAY_DURATION = exports.getFirstDayOfMonth = exports.getDayCountOfMonth = exports.parseDate = exports.formatDate = exports.isDate = exports.toDate = exports.equalDate = undefined;
-
- var _date = __webpack_require__(154);
-
- var _date2 = _interopRequireDefault(_date);
+ exports.getRowIdentity = exports.mousewheel = exports.getColumnByCell = exports.getColumnById = exports.orderBy = exports.getCell = undefined;
- var _locale = __webpack_require__(111);
+ 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; };
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _util = __webpack_require__(107);
- var weeks = ['sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat'];
- var months = ['jan', 'feb', 'mar', 'apr', 'may', 'jun', 'jul', 'aug', 'sep', 'oct', 'nov', 'dec'];
- var getI18nSettings = function getI18nSettings() {
- return {
- dayNamesShort: weeks.map(function (week) {
- return (0, _locale.t)('el.datepicker.weeks.' + week);
- }),
- dayNames: weeks.map(function (week) {
- return (0, _locale.t)('el.datepicker.weeks.' + week);
- }),
- monthNamesShort: months.map(function (month) {
- return (0, _locale.t)('el.datepicker.months.' + month);
- }),
- monthNames: months.map(function (month, index) {
- return (0, _locale.t)('el.datepicker.month' + (index + 1));
- }),
- amPm: ['am', 'pm']
- };
- };
+ var getCell = exports.getCell = function getCell(event) {
+ var cell = event.target;
- var newArray = function newArray(start, end) {
- var result = [];
- for (var i = start; i <= end; i++) {
- result.push(i);
+ while (cell && cell.tagName.toUpperCase() !== 'HTML') {
+ if (cell.tagName.toUpperCase() === 'TD') {
+ return cell;
+ }
+ cell = cell.parentNode;
}
- return result;
- };
-
- var equalDate = exports.equalDate = function equalDate(dateA, dateB) {
- return dateA === dateB || new Date(dateA).getTime() === new Date(dateB).getTime();
- };
-
- var toDate = exports.toDate = function toDate(date) {
- return isDate(date) ? new Date(date) : null;
- };
-
- var isDate = exports.isDate = function isDate(date) {
- if (date === null || date === undefined) return false;
- if (isNaN(new Date(date).getTime())) return false;
- return true;
- };
- var formatDate = exports.formatDate = function formatDate(date, format) {
- date = toDate(date);
- if (!date) return '';
- return _date2.default.format(date, format || 'yyyy-MM-dd', getI18nSettings());
+ return null;
};
- var parseDate = exports.parseDate = function parseDate(string, format) {
- return _date2.default.parse(string, format || 'yyyy-MM-dd', getI18nSettings());
+ var isObject = function isObject(obj) {
+ return obj !== null && (typeof obj === 'undefined' ? 'undefined' : _typeof(obj)) === 'object';
};
- var getDayCountOfMonth = exports.getDayCountOfMonth = function getDayCountOfMonth(year, month) {
- if (month === 3 || month === 5 || month === 8 || month === 10) {
- return 30;
+ var orderBy = exports.orderBy = function orderBy(array, sortKey, reverse, sortMethod) {
+ if (typeof reverse === 'string') {
+ reverse = reverse === 'descending' ? -1 : 1;
}
-
- if (month === 1) {
- if (year % 4 === 0 && year % 100 !== 0 || year % 400 === 0) {
- return 29;
- } else {
- return 28;
- }
+ if (!sortKey && !sortMethod) {
+ return array;
}
+ var order = reverse && reverse < 0 ? -1 : 1;
- return 31;
+ // sort on a copy to avoid mutating original array
+ return array.slice().sort(sortMethod ? function (a, b) {
+ return sortMethod(a, b) ? order : -order;
+ } : function (a, b) {
+ if (sortKey !== '$key') {
+ if (isObject(a) && '$value' in a) a = a.$value;
+ if (isObject(b) && '$value' in b) b = b.$value;
+ }
+ a = isObject(a) ? (0, _util.getValueByPath)(a, sortKey) : a;
+ b = isObject(b) ? (0, _util.getValueByPath)(b, sortKey) : b;
+ return a === b ? 0 : a > b ? order : -order;
+ });
};
- var getFirstDayOfMonth = exports.getFirstDayOfMonth = function getFirstDayOfMonth(date) {
- var temp = new Date(date.getTime());
- temp.setDate(1);
- return temp.getDay();
+ var getColumnById = exports.getColumnById = function getColumnById(table, columnId) {
+ var column = null;
+ table.columns.forEach(function (item) {
+ if (item.id === columnId) {
+ column = item;
+ }
+ });
+ return column;
};
- var DAY_DURATION = exports.DAY_DURATION = 86400000;
+ var getColumnByCell = exports.getColumnByCell = function getColumnByCell(table, cell) {
+ var matches = (cell.className || '').match(/el-table_[^\s]+/gm);
+ if (matches) {
+ return getColumnById(table, matches[0]);
+ }
+ return null;
+ };
- var getStartDateOfMonth = exports.getStartDateOfMonth = function getStartDateOfMonth(year, month) {
- var result = new Date(year, month, 1);
- var day = result.getDay();
+ var isFirefox = typeof navigator !== 'undefined' && navigator.userAgent.toLowerCase().indexOf('firefox') > -1;
- if (day === 0) {
- result.setTime(result.getTime() - DAY_DURATION * 7);
- } else {
- result.setTime(result.getTime() - DAY_DURATION * day);
+ var mousewheel = exports.mousewheel = function mousewheel(element, callback) {
+ if (element && element.addEventListener) {
+ element.addEventListener(isFirefox ? 'DOMMouseScroll' : 'mousewheel', callback);
}
-
- return result;
};
- var getWeekNumber = exports.getWeekNumber = function getWeekNumber(src) {
- var date = new Date(src.getTime());
- date.setHours(0, 0, 0, 0);
- // Thursday in current week decides the year.
- date.setDate(date.getDate() + 3 - (date.getDay() + 6) % 7);
- // January 4 is always in week 1.
- var week1 = new Date(date.getFullYear(), 0, 4);
- // Adjust to Thursday in week 1 and count number of weeks from date to week 1.
- return 1 + Math.round(((date.getTime() - week1.getTime()) / 86400000 - 3 + (week1.getDay() + 6) % 7) / 7);
+ var getRowIdentity = exports.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 prevMonth = exports.prevMonth = function prevMonth(src) {
- var year = src.getFullYear();
- var month = src.getMonth();
- var date = src.getDate();
-
- var newYear = month === 0 ? year - 1 : year;
- var newMonth = month === 0 ? 11 : month - 1;
-
- var newMonthDayCount = getDayCountOfMonth(newYear, newMonth);
- if (newMonthDayCount < date) {
- src.setDate(newMonthDayCount);
- }
+/***/ },
+/* 135 */
+/***/ function(module, exports, __webpack_require__) {
- src.setMonth(newMonth);
- src.setFullYear(newYear);
+ 'use strict';
- return new Date(src.getTime());
- };
+ exports.__esModule = true;
- var nextMonth = exports.nextMonth = function nextMonth(src) {
- var year = src.getFullYear();
- var month = src.getMonth();
- var date = src.getDate();
+ var _scrollbarWidth = __webpack_require__(136);
- var newYear = month === 11 ? year + 1 : year;
- var newMonth = month === 11 ? 0 : month + 1;
+ var _scrollbarWidth2 = _interopRequireDefault(_scrollbarWidth);
- var newMonthDayCount = getDayCountOfMonth(newYear, newMonth);
- if (newMonthDayCount < date) {
- src.setDate(newMonthDayCount);
- }
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- src.setMonth(newMonth);
- src.setFullYear(newYear);
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- return new Date(src.getTime());
- };
+ var TableLayout = function () {
+ function TableLayout(options) {
+ _classCallCheck(this, TableLayout);
- var getRangeHours = exports.getRangeHours = function getRangeHours(ranges) {
- var hours = [];
- var disabledHours = [];
+ this.table = null;
+ this.store = null;
+ this.columns = null;
+ this.fit = true;
+ this.showHeader = true;
- (ranges || []).forEach(function (range) {
- var value = range.map(function (date) {
- return date.getHours();
- });
+ 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.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 = (0, _scrollbarWidth2.default)();
- disabledHours = disabledHours.concat(newArray(value[0], value[1]));
- });
+ for (var name in options) {
+ if (options.hasOwnProperty(name)) {
+ this[name] = options[name];
+ }
+ }
- if (disabledHours.length) {
- for (var i = 0; i < 24; i++) {
- hours[i] = disabledHours.indexOf(i) === -1;
+ if (!this.table) {
+ throw new Error('table is required for Table Layout');
}
- } else {
- for (var _i = 0; _i < 24; _i++) {
- hours[_i] = false;
+ if (!this.store) {
+ throw new Error('store is required for Table Layout');
}
}
- return hours;
- };
-
- var limitRange = exports.limitRange = function limitRange(date, ranges) {
- var format = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'yyyy-MM-dd HH:mm:ss';
-
- if (!ranges || !ranges.length) return date;
+ TableLayout.prototype.updateScrollY = function updateScrollY() {
+ var height = this.height;
+ if (typeof height !== 'string' && typeof height !== 'number') return;
+ var bodyWrapper = this.table.bodyWrapper;
+ if (this.table.$el && bodyWrapper) {
+ var body = bodyWrapper.querySelector('.el-table__body');
+ this.scrollY = body.offsetHeight > bodyWrapper.offsetHeight;
+ }
+ };
- var len = ranges.length;
+ TableLayout.prototype.setHeight = function setHeight(value) {
+ var prop = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'height';
- date = _date2.default.parse(_date2.default.format(date, format), format);
- for (var i = 0; i < len; i++) {
- var range = ranges[i];
- if (date >= range[0] && date <= range[1]) {
- return date;
+ var el = this.table.$el;
+ if (typeof value === 'string' && /^\d+$/.test(value)) {
+ value = Number(value);
}
- }
-
- var maxDate = ranges[0][0];
- var minDate = ranges[0][0];
- ranges.forEach(function (range) {
- minDate = new Date(Math.min(range[0], minDate));
- maxDate = new Date(Math.max(range[1], maxDate));
- });
+ this.height = value;
- return date < minDate ? minDate : maxDate;
- };
+ if (!el) return;
+ if (typeof value === 'number') {
+ el.style[prop] = value + 'px';
-/***/ },
-/* 154 */
-/***/ function(module, exports) {
+ this.updateHeight();
+ } else if (typeof value === 'string') {
+ if (value === '') {
+ el.style[prop] = '';
+ }
+ this.updateHeight();
+ }
+ };
- module.exports = __webpack_require__(54);
+ TableLayout.prototype.setMaxHeight = function setMaxHeight(value) {
+ return this.setHeight(value, 'max-height');
+ };
-/***/ },
-/* 155 */
-/***/ function(module, exports) {
+ TableLayout.prototype.updateHeight = function updateHeight() {
+ var height = this.tableHeight = this.table.$el.clientHeight;
+ var noData = !this.table.data || this.table.data.length === 0;
+ var _table$$refs = this.table.$refs,
+ headerWrapper = _table$$refs.headerWrapper,
+ footerWrapper = _table$$refs.footerWrapper;
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('el-input', {
- 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,
- "disabled": _vm.disabled,
- "size": _vm.size,
- "placeholder": _vm.placeholder,
- "value": _vm.displayValue,
- "validateEvent": false
- },
- on: {
- "focus": _vm.handleFocus,
- "blur": _vm.handleBlur
- },
- nativeOn: {
- "keydown": function($event) {
- _vm.handleKeydown($event)
- },
- "change": function($event) {
- _vm.displayValue = $event.target.value
+ var footerHeight = this.footerHeight = footerWrapper ? footerWrapper.offsetHeight : 0;
+ if (this.showHeader && !headerWrapper) return;
+ if (!this.showHeader) {
+ this.headerHeight = 0;
+ if (this.height !== null && (!isNaN(this.height) || typeof this.height === 'string')) {
+ this.bodyHeight = height - footerHeight + (footerWrapper ? 1 : 0);
}
- }
- }, [(_vm.haveTrigger) ? _c('i', {
- staticClass: "el-input__icon",
- class: [_vm.showClose ? 'el-icon-close' : _vm.triggerClass],
- on: {
- "click": _vm.handleClickIcon,
- "mouseenter": _vm.handleMouseEnterIcon,
- "mouseleave": function($event) {
- _vm.showClose = false
+ this.fixedBodyHeight = this.scrollX ? height - this.gutterWidth : height;
+ } else {
+ var headerHeight = this.headerHeight = headerWrapper.offsetHeight;
+ var bodyHeight = height - headerHeight - footerHeight + (footerWrapper ? 1 : 0);
+ if (this.height !== null && (!isNaN(this.height) || typeof this.height === 'string')) {
+ this.bodyHeight = bodyHeight;
}
- },
- slot: "icon"
- }) : _vm._e()])
- },staticRenderFns: []}
+ this.fixedBodyHeight = this.scrollX ? bodyHeight - this.gutterWidth : bodyHeight;
+ }
+ this.viewportHeight = this.scrollX ? height - (noData ? 0 : this.gutterWidth) : height;
+ };
-/***/ },
-/* 156 */
-/***/ function(module, exports, __webpack_require__) {
+ TableLayout.prototype.update = function update() {
+ var fit = this.fit;
+ var columns = this.table.columns;
+ var bodyWidth = this.table.$el.clientWidth;
+ var bodyMinWidth = 0;
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(157),
- /* template */
- __webpack_require__(173),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ var flattenColumns = [];
+ columns.forEach(function (column) {
+ if (column.isColumnGroup) {
+ flattenColumns.push.apply(flattenColumns, column.columns);
+ } else {
+ flattenColumns.push(column);
+ }
+ });
- module.exports = Component.exports
+ var flexColumns = flattenColumns.filter(function (column) {
+ return typeof column.width !== 'number';
+ });
+ if (flexColumns.length > 0 && fit) {
+ flattenColumns.forEach(function (column) {
+ bodyMinWidth += column.width || column.minWidth || 80;
+ });
-/***/ },
-/* 157 */
-/***/ function(module, exports, __webpack_require__) {
+ if (bodyMinWidth < bodyWidth - this.gutterWidth) {
+ // DON'T HAVE SCROLL BAR
+ this.scrollX = false;
- 'use strict';
+ var totalFlexWidth = bodyWidth - this.gutterWidth - bodyMinWidth;
- exports.__esModule = true;
+ if (flexColumns.length === 1) {
+ flexColumns[0].realWidth = (flexColumns[0].minWidth || 80) + totalFlexWidth;
+ } else {
+ (function () {
+ var allColumnsWidth = flexColumns.reduce(function (prev, column) {
+ return prev + (column.minWidth || 80);
+ }, 0);
+ var flexWidthPerPixel = totalFlexWidth / allColumnsWidth;
+ var noneFirstWidth = 0;
- var _util = __webpack_require__(153);
+ 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;
+ });
- var _locale = __webpack_require__(10);
+ 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;
+ });
+ }
- var _locale2 = _interopRequireDefault(_locale);
+ this.bodyWidth = Math.max(bodyMinWidth, bodyWidth);
+ } else {
+ flattenColumns.forEach(function (column) {
+ if (!column.width && !column.minWidth) {
+ column.realWidth = 80;
+ } else {
+ column.realWidth = column.width || column.minWidth;
+ }
- var _input = __webpack_require__(20);
+ bodyMinWidth += column.realWidth;
+ });
+ this.scrollX = bodyMinWidth > bodyWidth;
- var _input2 = _interopRequireDefault(_input);
+ this.bodyWidth = bodyMinWidth;
+ }
- var _time = __webpack_require__(158);
+ var fixedColumns = this.store.states.fixedColumns;
- var _time2 = _interopRequireDefault(_time);
+ if (fixedColumns.length > 0) {
+ var fixedWidth = 0;
+ fixedColumns.forEach(function (column) {
+ fixedWidth += column.realWidth;
+ });
- var _yearTable = __webpack_require__(164);
+ this.fixedWidth = fixedWidth;
+ }
- var _yearTable2 = _interopRequireDefault(_yearTable);
+ var rightFixedColumns = this.store.states.rightFixedColumns;
+ if (rightFixedColumns.length > 0) {
+ var rightFixedWidth = 0;
+ rightFixedColumns.forEach(function (column) {
+ rightFixedWidth += column.realWidth;
+ });
- var _monthTable = __webpack_require__(167);
+ this.rightFixedWidth = rightFixedWidth;
+ }
+ };
- var _monthTable2 = _interopRequireDefault(_monthTable);
+ return TableLayout;
+ }();
- var _dateTable = __webpack_require__(170);
+ exports.default = TableLayout;
- var _dateTable2 = _interopRequireDefault(_dateTable);
+/***/ },
+/* 136 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(14);
+
+/***/ },
+/* 137 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _util = __webpack_require__(134);
+
+ var _dom = __webpack_require__(44);
+
+ var _checkbox = __webpack_require__(130);
+
+ var _checkbox2 = _interopRequireDefault(_checkbox);
+
+ var _tooltip = __webpack_require__(138);
+
+ var _tooltip2 = _interopRequireDefault(_tooltip);
+
+ var _debounce = __webpack_require__(69);
+
+ var _debounce2 = _interopRequireDefault(_debounce);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- mixins: [_locale2.default],
-
- watch: {
- showTime: function showTime(val) {
- var _this = this;
+ components: {
+ ElCheckbox: _checkbox2.default,
+ ElTooltip: _tooltip2.default
+ },
- /* istanbul ignore if */
- if (!val) return;
- this.$nextTick(function (_) {
- var inputElm = _this.$refs.input.$el;
- if (inputElm) {
- _this.pickerWidth = inputElm.getBoundingClientRect().width + 10;
- }
- });
+ props: {
+ store: {
+ required: true
},
- value: function value(newVal) {
- if (!newVal) return;
- newVal = new Date(newVal);
- if (!isNaN(newVal)) {
- if (typeof this.disabledDate === 'function' && this.disabledDate(new Date(newVal))) {
- return;
- }
- this.date = newVal;
- this.year = newVal.getFullYear();
- this.month = newVal.getMonth();
- this.$emit('pick', newVal, false);
- }
+ stripe: Boolean,
+ context: {},
+ layout: {
+ required: true
},
- timePickerVisible: function timePickerVisible(val) {
- var _this2 = this;
+ rowClassName: [String, Function],
+ rowStyle: [Object, Function],
+ fixed: String,
+ highlight: Boolean
+ },
- if (val) this.$nextTick(function () {
- return _this2.$refs.timepicker.ajustScrollTop();
- });
- },
- selectionMode: function selectionMode(newVal) {
- if (newVal === 'month') {
- /* istanbul ignore next */
- if (this.currentView !== 'year' || this.currentView !== 'month') {
- this.currentView = 'month';
- }
- } else if (newVal === 'week') {
- this.week = (0, _util.getWeekNumber)(this.date);
+ render: function render(h) {
+ var _this = this;
+
+ var columnsHidden = this.columns.map(function (column, index) {
+ return _this.isColumnHidden(index);
+ });
+ return h(
+ 'table',
+ {
+ 'class': 'el-table__body',
+ attrs: { cellspacing: '0',
+ cellpadding: '0',
+ border: '0' }
+ },
+ [h(
+ 'colgroup',
+ null,
+ [this._l(this.columns, function (column) {
+ return h(
+ 'col',
+ {
+ attrs: {
+ name: column.id,
+ width: column.realWidth || column.width
+ }
+ },
+ []
+ );
+ })]
+ ), h(
+ 'tbody',
+ null,
+ [this._l(this.data, function (row, $index) {
+ return [h(
+ 'tr',
+ {
+ style: _this.rowStyle ? _this.getRowStyle(row, $index) : null,
+ key: _this.table.rowKey ? _this.getKeyOfRow(row, $index) : $index,
+ on: {
+ 'dblclick': function dblclick($event) {
+ return _this.handleDoubleClick($event, row);
+ },
+ 'click': function click($event) {
+ return _this.handleClick($event, row);
+ },
+ 'contextmenu': function contextmenu($event) {
+ return _this.handleContextMenu($event, row);
+ },
+ 'mouseenter': function mouseenter(_) {
+ return _this.handleMouseEnter($index);
+ },
+ 'mouseleave': function mouseleave(_) {
+ return _this.handleMouseLeave();
+ }
+ },
+
+ 'class': [_this.getRowClass(row, $index)] },
+ [_this._l(_this.columns, function (column, cellIndex) {
+ return h(
+ 'td',
+ {
+ 'class': [column.id, column.align, column.className || '', columnsHidden[cellIndex] ? 'is-hidden' : ''],
+ on: {
+ 'mouseenter': function mouseenter($event) {
+ return _this.handleCellMouseEnter($event, row);
+ },
+ 'mouseleave': _this.handleCellMouseLeave
+ }
+ },
+ [column.renderCell.call(_this._renderProxy, h, { row: row, column: column, $index: $index, store: _this.store, _self: _this.context || _this.table.$vnode.context }, columnsHidden[cellIndex])]
+ );
+ }), !_this.fixed && _this.layout.scrollY && _this.layout.gutterWidth ? h(
+ 'td',
+ { 'class': 'gutter' },
+ []
+ ) : '']
+ ), _this.store.states.expandRows.indexOf(row) > -1 ? h(
+ 'tr',
+ null,
+ [h(
+ 'td',
+ {
+ attrs: { colspan: _this.columns.length },
+ 'class': 'el-table__expanded-cell' },
+ [_this.table.renderExpanded ? _this.table.renderExpanded(h, { row: row, $index: $index, store: _this.store }) : '']
+ )]
+ ) : ''];
+ }).concat(this._self.$parent.$slots.append).concat(h(
+ 'el-tooltip',
+ {
+ attrs: { effect: this.table.tooltipEffect, placement: 'top', content: this.tooltipContent },
+ ref: 'tooltip' },
+ []
+ ))]
+ )]
+ );
+ },
+
+
+ watch: {
+ 'store.states.hoverRow': function storeStatesHoverRow(newVal, oldVal) {
+ if (!this.store.states.isComplex) return;
+ var el = this.$el;
+ if (!el) return;
+ var rows = el.querySelectorAll('tbody > tr.el-table__row');
+ var oldRow = rows[oldVal];
+ var newRow = rows[newVal];
+ if (oldRow) {
+ (0, _dom.removeClass)(oldRow, 'hover-row');
+ }
+ if (newRow) {
+ (0, _dom.addClass)(newRow, 'hover-row');
}
},
- date: function date(newVal) {
- this.year = newVal.getFullYear();
- this.month = newVal.getMonth();
- if (this.selectionMode === 'week') this.week = (0, _util.getWeekNumber)(newVal);
+ 'store.states.currentRow': function storeStatesCurrentRow(newVal, oldVal) {
+ if (!this.highlight) return;
+ var el = this.$el;
+ if (!el) return;
+ var data = this.store.states.data;
+ var rows = el.querySelectorAll('tbody > tr.el-table__row');
+ var oldRow = rows[data.indexOf(oldVal)];
+ var newRow = rows[data.indexOf(newVal)];
+ if (oldRow) {
+ (0, _dom.removeClass)(oldRow, 'current-row');
+ } else if (rows) {
+ [].forEach.call(rows, function (row) {
+ return (0, _dom.removeClass)(row, 'current-row');
+ });
+ }
+ if (newRow) {
+ (0, _dom.addClass)(newRow, 'current-row');
+ }
}
},
- methods: {
- handleClear: function handleClear() {
- this.date = this.$options.defaultValue ? new Date(this.$options.defaultValue) : new Date();
- this.$emit('pick');
+ computed: {
+ table: function table() {
+ return this.$parent;
},
- resetDate: function resetDate() {
- this.date = new Date(this.date);
+ data: function data() {
+ return this.store.states.data;
},
- showMonthPicker: function showMonthPicker() {
- this.currentView = 'month';
+ columnsCount: function columnsCount() {
+ return this.store.states.columns.length;
},
- showYearPicker: function showYearPicker() {
- this.currentView = 'year';
+ leftFixedCount: function leftFixedCount() {
+ return this.store.states.fixedColumns.length;
+ },
+ rightFixedCount: function rightFixedCount() {
+ return this.store.states.rightFixedColumns.length;
},
+ columns: function columns() {
+ return this.store.states.columns;
+ }
+ },
+ data: function data() {
+ return {
+ tooltipContent: ''
+ };
+ },
+ created: function created() {
+ this.activateTooltip = (0, _debounce2.default)(50, function (tooltip) {
+ return tooltip.handleShowPopper();
+ });
+ },
- // XXX: 没用到
- // handleLabelClick() {
- // if (this.currentView === 'date') {
- // this.showMonthPicker();
- // } else if (this.currentView === 'month') {
- // this.showYearPicker();
- // }
- // },
- prevMonth: function prevMonth() {
- this.month--;
- if (this.month < 0) {
- this.month = 11;
- this.year--;
- }
- },
- nextMonth: function nextMonth() {
- this.month++;
- if (this.month > 11) {
- this.month = 0;
- this.year++;
- }
- },
- nextYear: function nextYear() {
- if (this.currentView === 'year') {
- this.$refs.yearTable.nextTenYear();
- } else {
- this.year++;
- this.date.setFullYear(this.year);
- this.resetDate();
+ methods: {
+ getKeyOfRow: function getKeyOfRow(row, index) {
+ var rowKey = this.table.rowKey;
+ if (rowKey) {
+ return (0, _util.getRowIdentity)(row, rowKey);
}
+ return index;
},
- prevYear: function prevYear() {
- if (this.currentView === 'year') {
- this.$refs.yearTable.prevTenYear();
+ isColumnHidden: function isColumnHidden(index) {
+ if (this.fixed === true || this.fixed === 'left') {
+ return index >= this.leftFixedCount;
+ } else if (this.fixed === 'right') {
+ return index < this.columnsCount - this.rightFixedCount;
} else {
- this.year--;
- this.date.setFullYear(this.year);
- this.resetDate();
+ return index < this.leftFixedCount || index >= this.columnsCount - this.rightFixedCount;
}
},
- handleShortcutClick: function handleShortcutClick(shortcut) {
- if (shortcut.onClick) {
- shortcut.onClick(this);
+ getRowStyle: function getRowStyle(row, index) {
+ var rowStyle = this.rowStyle;
+ if (typeof rowStyle === 'function') {
+ return rowStyle.call(null, row, index);
}
+ return rowStyle;
},
- handleTimePick: function handleTimePick(picker, visible, first) {
- if (picker) {
- var oldDate = new Date(this.date.getTime());
- var hour = picker.getHours();
- var minute = picker.getMinutes();
- var second = picker.getSeconds();
- oldDate.setHours(hour);
- oldDate.setMinutes(minute);
- oldDate.setSeconds(second);
- this.date = new Date(oldDate.getTime());
- }
+ getRowClass: function getRowClass(row, index) {
+ var classes = ['el-table__row'];
- if (!first) {
- this.timePickerVisible = visible;
+ if (this.stripe && index % 2 === 1) {
+ classes.push('el-table__row--striped');
}
- },
- handleMonthPick: function handleMonthPick(month) {
- this.month = month;
- var selectionMode = this.selectionMode;
- if (selectionMode !== 'month') {
- this.date.setMonth(month);
- this.currentView = 'date';
- this.resetDate();
- } else {
- this.date.setMonth(month);
- this.year && this.date.setFullYear(this.year);
- this.resetDate();
- var value = new Date(this.date.getFullYear(), month, 1);
- this.$emit('pick', value);
+ var rowClassName = this.rowClassName;
+ if (typeof rowClassName === 'string') {
+ classes.push(rowClassName);
+ } else if (typeof rowClassName === 'function') {
+ classes.push(rowClassName.call(null, row, index) || '');
}
+
+ return classes.join(' ');
},
- handleDatePick: function handleDatePick(value) {
- if (this.selectionMode === 'day') {
- if (!this.showTime) {
- this.$emit('pick', new Date(value.getTime()));
- }
- this.date.setFullYear(value.getFullYear());
- this.date.setMonth(value.getMonth(), value.getDate());
- } else if (this.selectionMode === 'week') {
- this.week = value.week;
- this.$emit('pick', value.date);
+ handleCellMouseEnter: function handleCellMouseEnter(event, row) {
+ var table = this.table;
+ var cell = (0, _util.getCell)(event);
+
+ if (cell) {
+ var column = (0, _util.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);
}
- this.resetDate();
- },
- handleYearPick: function handleYearPick(year) {
- var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
+ // 判断是否text-overflow, 如果是就显示tooltip
+ var cellChild = event.target.querySelector('.cell');
- this.year = year;
- if (!close) return;
+ if ((0, _dom.hasClass)(cellChild, 'el-tooltip') && cellChild.scrollWidth > cellChild.offsetWidth) {
+ var tooltip = this.$refs.tooltip;
- this.date.setFullYear(year);
- if (this.selectionMode === 'year') {
- this.$emit('pick', new Date(year, 0, 1));
- } else {
- this.currentView = 'month';
+ this.tooltipContent = cell.innerText;
+ 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 = (0, _util.getCell)(event);
+ if (!cell) return;
- this.resetDate();
+ var oldHoverState = this.table.hoverState;
+ this.table.$emit('cell-mouse-leave', oldHoverState.row, oldHoverState.column, oldHoverState.cell, event);
},
- changeToNow: function changeToNow() {
- this.date.setTime(+new Date());
- this.$emit('pick', new Date(this.date.getTime()));
- this.resetDate();
+ handleMouseEnter: function handleMouseEnter(index) {
+ this.store.commit('setHoverRow', index);
},
- confirm: function confirm() {
- this.date.setMilliseconds(0);
- this.$emit('pick', this.date);
+ handleMouseLeave: function handleMouseLeave() {
+ this.store.commit('setHoverRow', null);
},
- resetView: function resetView() {
- if (this.selectionMode === 'month') {
- this.currentView = 'month';
- } else if (this.selectionMode === 'year') {
- this.currentView = 'year';
- } else {
- this.currentView = 'date';
- }
-
- if (this.selectionMode !== 'week') {
- this.year = this.date.getFullYear();
- this.month = this.date.getMonth();
+ 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 = (0, _util.getCell)(event);
+ var column = void 0;
+ if (cell) {
+ column = (0, _util.getColumnByCell)(table, cell);
+ if (column) {
+ table.$emit('cell-' + name, row, column, cell, event);
+ }
}
+ table.$emit('row-' + name, row, event, column);
+ },
+ handleExpandClick: function handleExpandClick(row) {
+ this.store.commit('toggleRowExpanded', row);
}
- },
+ }
+ };
- components: {
- TimePicker: _time2.default, YearTable: _yearTable2.default, MonthTable: _monthTable2.default, DateTable: _dateTable2.default, ElInput: _input2.default
- },
+/***/ },
+/* 138 */
+/***/ function(module, exports) {
- mounted: function mounted() {
- if (this.date && !this.year) {
- this.year = this.date.getFullYear();
- this.month = this.date.getMonth();
- }
- },
- data: function data() {
- return {
- popperClass: '',
- pickerWidth: 0,
- date: this.$options.defaultValue ? new Date(this.$options.defaultValue) : new Date(),
- value: '',
- showTime: false,
- selectionMode: 'day',
- shortcuts: '',
- visible: false,
- currentView: 'date',
- disabledDate: '',
- firstDayOfWeek: 7,
- year: null,
- month: null,
- week: null,
- showWeekNumber: false,
- timePickerVisible: false,
- width: 0,
- format: ''
- };
- },
+ module.exports = __webpack_require__(53);
+/***/ },
+/* 139 */
+/***/ function(module, exports, __webpack_require__) {
- computed: {
- footerVisible: function footerVisible() {
- return this.showTime;
- },
+ 'use strict';
+ exports.__esModule = true;
- visibleTime: {
- get: function get() {
- return (0, _util.formatDate)(this.date, this.timeFormat);
- },
- set: function set(val) {
- if (val) {
- var date = (0, _util.parseDate)(val, this.timeFormat);
- if (date) {
- date.setFullYear(this.date.getFullYear());
- date.setMonth(this.date.getMonth());
- date.setDate(this.date.getDate());
- this.date = date;
- this.$refs.timepicker.value = date;
- this.timePickerVisible = false;
- }
- }
- }
- },
+ var _dom = __webpack_require__(44);
- visibleDate: {
- get: function get() {
- return (0, _util.formatDate)(this.date, this.dateFormat);
- },
- set: function set(val) {
- var date = (0, _util.parseDate)(val, this.dateFormat);
- if (!date) {
- return;
- }
- if (typeof this.disabledDate === 'function' && this.disabledDate(date)) {
- return;
- }
- date.setHours(this.date.getHours());
- date.setMinutes(this.date.getMinutes());
- date.setSeconds(this.date.getSeconds());
- this.date = date;
- this.resetView();
- }
- },
+ var _checkbox = __webpack_require__(130);
- yearLabel: function yearLabel() {
- var year = this.year;
- if (!year) return '';
- var yearTranslation = this.t('el.datepicker.year');
- if (this.currentView === 'year') {
- var startYear = Math.floor(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 && this.format.indexOf('ss') === -1) {
- return 'HH:mm';
- } else {
- return 'HH:mm:ss';
- }
- },
- dateFormat: function dateFormat() {
- if (this.format) {
- return this.format.replace('HH:mm', '').replace(':ss', '').trim();
- } else {
- return 'yyyy-MM-dd';
- }
- }
- }
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ var _checkbox2 = _interopRequireDefault(_checkbox);
-/***/ },
-/* 158 */
-/***/ function(module, exports, __webpack_require__) {
+ var _tag = __webpack_require__(109);
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(159),
- /* template */
- __webpack_require__(163),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ var _tag2 = _interopRequireDefault(_tag);
- module.exports = Component.exports
+ var _vue = __webpack_require__(133);
+ var _vue2 = _interopRequireDefault(_vue);
-/***/ },
-/* 159 */
-/***/ function(module, exports, __webpack_require__) {
+ var _filterPanel = __webpack_require__(140);
- 'use strict';
+ var _filterPanel2 = _interopRequireDefault(_filterPanel);
- exports.__esModule = true;
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var _util = __webpack_require__(153);
+ 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 _locale = __webpack_require__(10);
+ 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;
+ }
+ };
- var _locale2 = _interopRequireDefault(_locale);
+ originColumns.forEach(function (column) {
+ column.level = 1;
+ traverse(column);
+ });
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ 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;
+ };
exports.default = {
- mixins: [_locale2.default],
+ name: 'ElTableHeader',
- components: {
- TimeSpinner: __webpack_require__(160)
+ render: function render(h) {
+ var _this = this;
+
+ var originColumns = this.store.states.originColumns;
+ var columnRows = convertToRows(originColumns, this.columns);
+
+ return h(
+ 'table',
+ {
+ 'class': 'el-table__header',
+ attrs: { cellspacing: '0',
+ cellpadding: '0',
+ border: '0' }
+ },
+ [h(
+ 'colgroup',
+ null,
+ [this._l(this.columns, function (column) {
+ return h(
+ 'col',
+ {
+ attrs: {
+ name: column.id,
+ width: column.realWidth || column.width
+ }
+ },
+ []
+ );
+ }), !this.fixed && this.layout.gutterWidth ? h(
+ 'col',
+ {
+ attrs: { name: 'gutter', width: this.layout.scrollY ? this.layout.gutterWidth : '' }
+ },
+ []
+ ) : '']
+ ), h(
+ 'thead',
+ null,
+ [this._l(columnRows, function (columns, rowIndex) {
+ return h(
+ 'tr',
+ null,
+ [_this._l(columns, 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);
+ }
+ },
+
+ 'class': [column.id, column.order, column.headerAlign, column.className || '', rowIndex === 0 && _this.isCellHidden(cellIndex, columns) ? 'is-hidden' : '', !column.children ? 'is-leaf' : '', column.labelClassName] },
+ [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.fixed && _this.layout.gutterWidth ? h(
+ 'th',
+ { 'class': 'gutter', style: { width: _this.layout.scrollY ? _this.layout.gutterWidth + 'px' : '0' } },
+ []
+ ) : '']
+ );
+ })]
+ )]
+ );
},
+
props: {
- pickerWidth: {},
- date: {
+ fixed: String,
+ store: {
+ required: true
+ },
+ layout: {
+ required: true
+ },
+ border: Boolean,
+ defaultSort: {
+ type: Object,
default: function _default() {
- return new Date();
+ return {
+ prop: '',
+ order: ''
+ };
}
- },
- visible: Boolean
+ }
},
- watch: {
- visible: function visible(val) {
- this.currentVisible = val;
+ components: {
+ ElCheckbox: _checkbox2.default,
+ ElTag: _tag2.default
+ },
+
+ computed: {
+ isAllSelected: function isAllSelected() {
+ return this.store.states.isAllSelected;
},
- pickerWidth: function pickerWidth(val) {
- this.width = val;
+ columnsCount: function columnsCount() {
+ return this.store.states.columns.length;
},
- value: function value(newVal) {
- var _this = this;
-
- var date = void 0;
- if (newVal instanceof Date) {
- date = (0, _util.limitRange)(newVal, this.selectableRange);
- } else if (!newVal) {
- date = new Date();
- }
-
- this.handleChange({
- hours: date.getHours(),
- minutes: date.getMinutes(),
- seconds: date.getSeconds()
- });
- this.$nextTick(function (_) {
- return _this.ajustScrollTop();
- });
+ leftFixedCount: function leftFixedCount() {
+ return this.store.states.fixedColumns.length;
},
- selectableRange: function selectableRange(val) {
- this.$refs.spinner.selectableRange = val;
+ rightFixedCount: function rightFixedCount() {
+ return this.store.states.rightFixedColumns.length;
+ },
+ columns: function columns() {
+ return this.store.states.columns;
}
},
- data: function data() {
- return {
- popperClass: '',
- format: 'HH:mm:ss',
- value: '',
- hours: 0,
- minutes: 0,
- seconds: 0,
- selectableRange: [],
- currentDate: this.$options.defaultValue || this.date || new Date(),
- currentVisible: this.visible || false,
- width: this.pickerWidth || 0
- };
+ created: function created() {
+ this.filterPanels = {};
},
+ mounted: function mounted() {
+ var _this2 = this;
+ if (this.defaultSort.prop) {
+ (function () {
+ var states = _this2.store.states;
+ states.sortProp = _this2.defaultSort.prop;
+ states.sortOrder = _this2.defaultSort.order || 'ascending';
+ _this2.$nextTick(function (_) {
+ for (var i = 0, length = _this2.columns.length; i < length; i++) {
+ var column = _this2.columns[i];
+ if (column.property === states.sortProp) {
+ column.order = states.sortOrder;
+ states.sortingColumn = column;
+ break;
+ }
+ }
- computed: {
- showSeconds: function showSeconds() {
- return (this.format || '').indexOf('ss') !== -1;
+ if (states.sortingColumn) {
+ _this2.store.commit('changeSortCondition');
+ }
+ });
+ })();
+ }
+ },
+ beforeDestroy: function beforeDestroy() {
+ var panels = this.filterPanels;
+ for (var prop in panels) {
+ if (panels.hasOwnProperty(prop) && panels[prop]) {
+ panels[prop].$destroy(true);
+ }
}
},
+
methods: {
- handleClear: function handleClear() {
- this.$emit('pick');
+ isCellHidden: function isCellHidden(index, columns) {
+ if (this.fixed === true || this.fixed === 'left') {
+ return index >= this.leftFixedCount;
+ } else if (this.fixed === 'right') {
+ var before = 0;
+ for (var i = 0; i < index; i++) {
+ before += columns[i].colSpan;
+ }
+ return before < this.columnsCount - this.rightFixedCount;
+ } else {
+ return index < this.leftFixedCount || index >= this.columnsCount - this.rightFixedCount;
+ }
},
- handleCancel: function handleCancel() {
- this.$emit('pick');
+ toggleAllSelection: function toggleAllSelection() {
+ this.store.commit('toggleAllSelection');
},
- handleChange: function handleChange(date) {
- if (date.hours !== undefined) {
- this.currentDate.setHours(date.hours);
- this.hours = this.currentDate.getHours();
+ handleFilterClick: function handleFilterClick(event, column) {
+ event.stopPropagation();
+ var target = event.target;
+ var cell = target.parentNode;
+ var table = this.$parent;
+
+ var filterPanel = this.filterPanels[column.id];
+
+ if (filterPanel && column.filterOpened) {
+ filterPanel.showPopper = false;
+ return;
}
- if (date.minutes !== undefined) {
- this.currentDate.setMinutes(date.minutes);
- this.minutes = this.currentDate.getMinutes();
+
+ if (!filterPanel) {
+ filterPanel = new _vue2.default(_filterPanel2.default);
+ 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'));
}
- if (date.seconds !== undefined) {
- this.currentDate.setSeconds(date.seconds);
- this.seconds = this.currentDate.getSeconds();
+
+ setTimeout(function () {
+ filterPanel.showPopper = true;
+ }, 16);
+ },
+ handleHeaderClick: function handleHeaderClick(event, column) {
+ if (!column.filters && column.sortable) {
+ this.handleSortClick(event, column);
+ } else if (column.filters && !column.sortable) {
+ this.handleFilterClick(event, column);
}
- this.handleConfirm(true);
+ this.$parent.$emit('header-click', column, event);
},
- setSelectionRange: function setSelectionRange(start, end) {
- this.$emit('select-range', start, end);
+ 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) {
+ (function () {
+ _this3.dragging = true;
+
+ _this3.$parent.resizeProxyVisible = true;
+
+ var table = _this3.$parent;
+ var tableEl = table.$el;
+ var tableLeft = tableEl.getBoundingClientRect().left;
+ var columnEl = _this3.$el.querySelector('th.' + column.id);
+ var columnRect = columnEl.getBoundingClientRect();
+ var minLeft = columnRect.left - tableLeft + 30;
+
+ (0, _dom.addClass)(columnEl, 'noclick');
+
+ _this3.dragState = {
+ startMouseLeft: event.clientX,
+ startLeft: columnRect.right - tableLeft,
+ startColumnLeft: columnRect.left - tableLeft,
+ tableLeft: tableLeft
+ };
+
+ var resizeProxy = table.$refs.resizeProxy;
+ resizeProxy.style.left = _this3.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 () {
+ (0, _dom.removeClass)(columnEl, 'noclick');
+ }, 0);
+ };
+
+ document.addEventListener('mousemove', handleMouseMove);
+ document.addEventListener('mouseup', handleMouseUp);
+ })();
+ }
},
- handleConfirm: function handleConfirm() {
- var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- var first = arguments[1];
+ 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 (first) return;
- var date = new Date((0, _util.limitRange)(this.currentDate, this.selectableRange, 'HH:mm:ss'));
- this.$emit('pick', date, visible, first);
+ 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';
+ this.draggingColumn = column;
+ } else if (!this.dragging) {
+ bodyStyle.cursor = '';
+ this.draggingColumn = null;
+ }
+ }
},
- ajustScrollTop: function ajustScrollTop() {
- return this.$refs.spinner.ajustScrollTop();
- }
- },
+ handleMouseOut: function handleMouseOut() {
+ if (this.$isServer) return;
+ document.body.style.cursor = '';
+ },
+ toggleOrder: function toggleOrder(order) {
+ return !order ? 'ascending' : order === 'ascending' ? 'descending' : null;
+ },
+ handleSortClick: function handleSortClick(event, column, givenOrder) {
+ event.stopPropagation();
+ var order = givenOrder || this.toggleOrder(column.order);
- created: function created() {
- this.hours = this.currentDate.getHours();
- this.minutes = this.currentDate.getMinutes();
- this.seconds = this.currentDate.getSeconds();
+ var target = event.target;
+ while (target && target.tagName !== 'TH') {
+ target = target.parentNode;
+ }
+
+ if (target && target.tagName === 'TH') {
+ if ((0, _dom.hasClass)(target, 'noclick')) {
+ (0, _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) {
+ if (sortingColumn) {
+ sortingColumn.order = null;
+ }
+ states.sortingColumn = column;
+ sortProp = column.property;
+ }
+
+ if (!order) {
+ sortOrder = column.order = null;
+ states.sortingColumn = null;
+ sortProp = null;
+ } else {
+ sortOrder = column.order = order;
+ }
+
+ states.sortProp = sortProp;
+ states.sortOrder = sortOrder;
+
+ this.store.commit('changeSortCondition');
+ }
},
- mounted: function mounted() {
- var _this2 = this;
- this.$nextTick(function () {
- return _this2.handleConfirm(true, true);
- });
- this.$emit('mounted');
+ data: function data() {
+ return {
+ draggingColumn: null,
+ dragging: false,
+ dragState: {}
+ };
}
};
/***/ },
-/* 160 */
+/* 140 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(161),
+ __webpack_require__(141),
/* template */
- __webpack_require__(162),
+ __webpack_require__(144),
/* styles */
null,
/* scopeId */
@@ -46131,157 +44719,206 @@ module.exports =
/***/ },
-/* 161 */
+/* 141 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _util = __webpack_require__(153);
+ var _vuePopper = __webpack_require__(24);
- var _scrollbar = __webpack_require__(25);
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
- var _scrollbar2 = _interopRequireDefault(_scrollbar);
+ var _popup = __webpack_require__(14);
- var _debounce = __webpack_require__(69);
+ var _locale = __webpack_require__(10);
- var _debounce2 = _interopRequireDefault(_debounce);
+ var _locale2 = _interopRequireDefault(_locale);
+
+ var _clickoutside = __webpack_require__(21);
+
+ var _clickoutside2 = _interopRequireDefault(_clickoutside);
+
+ var _dropdown = __webpack_require__(142);
+
+ var _dropdown2 = _interopRequireDefault(_dropdown);
+
+ var _checkbox = __webpack_require__(130);
+
+ var _checkbox2 = _interopRequireDefault(_checkbox);
+
+ var _checkboxGroup = __webpack_require__(143);
+
+ var _checkboxGroup2 = _interopRequireDefault(_checkboxGroup);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- components: { ElScrollbar: _scrollbar2.default },
+ name: 'ElTableFilterPanel',
- props: {
- hours: {
- type: Number,
- default: 0
- },
+ mixins: [_vuePopper2.default, _locale2.default],
- minutes: {
- type: Number,
- default: 0
- },
+ directives: {
+ Clickoutside: _clickoutside2.default
+ },
- seconds: {
- type: Number,
- default: 0
- },
+ components: {
+ ElCheckbox: _checkbox2.default,
+ ElCheckboxGroup: _checkboxGroup2.default
+ },
- showSeconds: {
- type: Boolean,
- default: true
+ props: {
+ placement: {
+ type: String,
+ default: 'bottom-end'
}
},
- watch: {
- hoursPrivate: function hoursPrivate(newVal, oldVal) {
- if (!(newVal >= 0 && newVal <= 23)) {
- this.hoursPrivate = oldVal;
- }
- this.ajustElTop('hour', newVal);
- this.$emit('change', { hours: newVal });
- },
- minutesPrivate: function minutesPrivate(newVal, oldVal) {
- if (!(newVal >= 0 && newVal <= 59)) {
- this.minutesPrivate = oldVal;
- }
- this.ajustElTop('minute', newVal);
- this.$emit('change', { minutes: newVal });
- },
- secondsPrivate: function secondsPrivate(newVal, oldVal) {
- if (!(newVal >= 0 && newVal <= 59)) {
- this.secondsPrivate = oldVal;
- }
- this.ajustElTop('second', newVal);
- this.$emit('change', { seconds: newVal });
- }
+ customRender: function customRender(h) {
+ return h(
+ 'div',
+ { 'class': 'el-table-filter' },
+ [h(
+ 'div',
+ { 'class': 'el-table-filter__content' },
+ []
+ ), h(
+ 'div',
+ { 'class': 'el-table-filter__bottom' },
+ [h(
+ 'button',
+ {
+ on: {
+ 'click': this.handleConfirm
+ }
+ },
+ [this.t('el.table.confirmFilter')]
+ ), h(
+ 'button',
+ {
+ on: {
+ 'click': this.handleReset
+ }
+ },
+ [this.t('el.table.resetFilter')]
+ )]
+ )]
+ );
},
- computed: {
- hoursList: function hoursList() {
- return (0, _util.getRangeHours)(this.selectableRange);
+
+ methods: {
+ isActive: function isActive(filter) {
+ return filter.value === this.filterValue;
},
- hourEl: function hourEl() {
- return this.$refs.hour.wrap;
+ handleOutsideClick: function handleOutsideClick() {
+ this.showPopper = false;
},
- minuteEl: function minuteEl() {
- return this.$refs.minute.wrap;
+ handleConfirm: function handleConfirm() {
+ this.confirmFilter(this.filteredValue);
+ this.handleOutsideClick();
},
- secondEl: function secondEl() {
- return this.$refs.second.wrap;
+ 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
+ });
}
},
data: function data() {
return {
- hoursPrivate: 0,
- minutesPrivate: 0,
- secondsPrivate: 0,
- selectableRange: []
+ table: null,
+ cell: null,
+ column: null
};
},
- created: function created() {
- var _this = this;
- this.debounceAjustElTop = (0, _debounce2.default)(100, function (type) {
- return _this.ajustElTop(type, _this[type + 's']);
- });
- },
- mounted: function mounted() {
- var _this2 = this;
- this.$nextTick(function () {
- _this2.bindScrollEvent();
- });
- },
+ computed: {
+ filters: function filters() {
+ return this.column && this.column.filters;
+ },
- methods: {
- handleClick: function handleClick(type, value, disabled) {
- if (value.disabled) {
- return;
+ 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);
+ }
+ }
}
-
- this[type + 'Private'] = value.value >= 0 ? value.value : value;
-
- this.emitSelectRange(type);
},
- 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);
+
+ filteredValue: {
+ get: function get() {
+ if (this.column) {
+ return this.column.filteredValue || [];
+ }
+ return [];
+ },
+ set: function set(value) {
+ if (this.column) {
+ this.column.filteredValue = value;
+ }
}
},
- bindScrollEvent: function bindScrollEvent() {
- var _this3 = this;
- var bindFuntion = function bindFuntion(type) {
- _this3[type + 'El'].onscroll = function (e) {
- return _this3.handleScroll(type, e);
- };
- };
- bindFuntion('hour');
- bindFuntion('minute');
- bindFuntion('second');
- },
- handleScroll: function handleScroll(type) {
- var ajust = {};
- ajust[type + 's'] = Math.min(Math.floor((this[type + 'El'].scrollTop - 80) / 32 + 3), '' + type === 'hour' ? 23 : 59);
- this.debounceAjustElTop(type);
- this.$emit('change', ajust);
- },
- ajustScrollTop: function ajustScrollTop() {
- this.ajustElTop('hour', this.hours);
- this.ajustElTop('minute', this.minutes);
- this.ajustElTop('second', this.seconds);
- },
- ajustElTop: function ajustElTop(type, value) {
- this[type + 'El'].scrollTop = Math.max(0, (value - 2.5) * 32 + 80);
+ multiple: function multiple() {
+ if (this.column) {
+ return this.column.filterMultiple;
+ }
+ return true;
+ }
+ },
+
+ mounted: function mounted() {
+ var _this = this;
+
+ this.popperElm = this.$el;
+ this.referenceElm = this.cell;
+ this.table.bodyWrapper.addEventListener('scroll', function () {
+ _this.updatePopper();
+ });
+
+ this.$watch('showPopper', function (value) {
+ if (_this.column) _this.column.filterOpened = value;
+ if (value) {
+ _dropdown2.default.open(_this);
+ } else {
+ _dropdown2.default.close(_this);
+ }
+ });
+ },
+
+ 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();
+ }
}
}
}; //
@@ -46318,1692 +44955,2264 @@ module.exports =
//
//
//
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
/***/ },
-/* 162 */
-/***/ function(module, exports) {
+/* 142 */
+/***/ function(module, exports, __webpack_require__) {
- module.exports={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
- }
- }, [_c('el-scrollbar', {
- ref: "hour",
- 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')
- }
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _vue = __webpack_require__(133);
+
+ var _vue2 = _interopRequireDefault(_vue);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ var dropdowns = [];
+
+ !_vue2.default.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;
}
- }, _vm._l((_vm.hoursList), function(disabled, hour) {
- return _c('li', {
- staticClass: "el-time-spinner__item",
- class: {
- 'active': hour === _vm.hours, 'disabled': disabled
- },
- attrs: {
- "track-by": "hour"
- },
- domProps: {
- "textContent": _vm._s(hour)
- },
- on: {
- "click": function($event) {
- _vm.handleClick('hours', {
- value: hour,
- disabled: disabled
- }, true)
- }
- }
- })
- })), _c('el-scrollbar', {
- ref: "minute",
- 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')
- }
+ dropdown.handleOutsideClick && dropdown.handleOutsideClick(event);
+ });
+ });
+
+ exports.default = {
+ open: function open(instance) {
+ if (instance) {
+ dropdowns.push(instance);
}
- }, _vm._l((60), function(minute, key) {
- return _c('li', {
- staticClass: "el-time-spinner__item",
- class: {
- 'active': key === _vm.minutes
- },
- domProps: {
- "textContent": _vm._s(key)
- },
- on: {
- "click": function($event) {
- _vm.handleClick('minutes', key, true)
- }
- }
- })
- })), _c('el-scrollbar', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.showSeconds),
- expression: "showSeconds"
- }],
- ref: "second",
- 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')
- }
+ },
+ close: function close(instance) {
+ var index = dropdowns.indexOf(instance);
+ if (index !== -1) {
+ dropdowns.splice(instance, 1);
}
- }, _vm._l((60), function(second, key) {
- return _c('li', {
- staticClass: "el-time-spinner__item",
- class: {
- 'active': key === _vm.seconds
- },
- domProps: {
- "textContent": _vm._s(key)
- },
- on: {
- "click": function($event) {
- _vm.handleClick('seconds', key, true)
- }
- }
- })
- }))], 1)
- },staticRenderFns: []}
+ }
+ };
/***/ },
-/* 163 */
+/* 143 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(54);
+
+/***/ },
+/* 144 */
/***/ function(module, exports) {
module.exports={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', {
+ }, [(_vm.multiple) ? _c('div', {
directives: [{
name: "show",
rawName: "v-show",
- value: (_vm.currentVisible),
- expression: "currentVisible"
+ value: (_vm.showPopper),
+ expression: "showPopper"
}],
- staticClass: "el-time-panel",
- class: _vm.popperClass,
- style: ({
- width: _vm.width + 'px'
- })
+ staticClass: "el-table-filter"
}, [_c('div', {
- staticClass: "el-time-panel__content",
- class: {
- 'has-seconds': _vm.showSeconds
+ staticClass: "el-table-filter__content"
+ }, [_c('el-checkbox-group', {
+ staticClass: "el-table-filter__checkbox-group",
+ model: {
+ value: (_vm.filteredValue),
+ callback: function($$v) {
+ _vm.filteredValue = $$v
+ },
+ expression: "filteredValue"
}
- }, [_c('time-spinner', {
- ref: "spinner",
+ }, _vm._l((_vm.filters), function(filter) {
+ return _c('el-checkbox', {
+ key: filter.value,
+ attrs: {
+ "label": filter.value
+ }
+ }, [_vm._v(_vm._s(filter.text))])
+ }))], 1), _c('div', {
+ staticClass: "el-table-filter__bottom"
+ }, [_c('button', {
+ class: {
+ 'is-disabled': _vm.filteredValue.length === 0
+ },
attrs: {
- "show-seconds": _vm.showSeconds,
- "hours": _vm.hours,
- "minutes": _vm.minutes,
- "seconds": _vm.seconds
+ "disabled": _vm.filteredValue.length === 0
},
on: {
- "change": _vm.handleChange,
- "select-range": _vm.setSelectionRange
+ "click": _vm.handleConfirm
}
- })], 1), _c('div', {
- staticClass: "el-time-panel__footer"
- }, [_c('button', {
- staticClass: "el-time-panel__btn cancel",
- attrs: {
- "type": "button"
- },
+ }, [_vm._v(_vm._s(_vm.t('el.table.confirmFilter')))]), _c('button', {
on: {
- "click": _vm.handleCancel
+ "click": _vm.handleReset
}
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.cancel')))]), _c('button', {
- staticClass: "el-time-panel__btn confirm",
- attrs: {
- "type": "button"
+ }, [_vm._v(_vm._s(_vm.t('el.table.resetFilter')))])])]) : _c('div', {
+ directives: [{
+ 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
},
on: {
"click": function($event) {
- _vm.handleConfirm()
+ _vm.handleSelect(null)
}
}
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.confirm')))])])])])
+ }, [_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)])])
},staticRenderFns: []}
/***/ },
-/* 164 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(165),
- /* template */
- __webpack_require__(166),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+/* 145 */
+/***/ function(module, exports) {
- module.exports = Component.exports
+ 'use strict';
+ exports.__esModule = true;
+ exports.default = {
+ name: 'ElTableFooter',
-/***/ },
-/* 165 */
-/***/ function(module, exports, __webpack_require__) {
+ render: function render(h) {
+ var _this = this;
- 'use strict';
+ var sums = [];
+ 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] = '';
+ }
+ });
- exports.__esModule = true;
+ return h(
+ 'table',
+ {
+ 'class': 'el-table__footer',
+ attrs: { cellspacing: '0',
+ cellpadding: '0',
+ border: '0' }
+ },
+ [h(
+ 'colgroup',
+ null,
+ [this._l(this.columns, function (column) {
+ return h(
+ 'col',
+ {
+ attrs: {
+ name: column.id,
+ width: column.realWidth || column.width
+ }
+ },
+ []
+ );
+ }), !this.fixed && this.layout.gutterWidth ? h(
+ 'col',
+ {
+ attrs: { name: 'gutter', width: this.layout.scrollY ? this.layout.gutterWidth : '' }
+ },
+ []
+ ) : '']
+ ), h(
+ 'tbody',
+ null,
+ [h(
+ 'tr',
+ null,
+ [this._l(this.columns, function (column, cellIndex) {
+ return h(
+ 'td',
+ {
+ attrs: {
+ colspan: column.colSpan,
+ rowspan: column.rowSpan
+ },
+ 'class': [column.id, column.headerAlign, column.className || '', _this.isCellHidden(cellIndex, _this.columns) ? 'is-hidden' : '', !column.children ? 'is-leaf' : '', column.labelClassName] },
+ [h(
+ 'div',
+ { 'class': ['cell', column.labelClassName] },
+ [_this.summaryMethod ? _this.summaryMethod({ columns: _this.columns, data: _this.store.states.data })[cellIndex] : sums[cellIndex]]
+ )]
+ );
+ }), !this.fixed && this.layout.gutterWidth ? h(
+ 'td',
+ { 'class': 'gutter', style: { width: this.layout.scrollY ? this.layout.gutterWidth + 'px' : '0' } },
+ []
+ ) : '']
+ )]
+ )]
+ );
+ },
- var _dom = __webpack_require__(44);
- exports.default = {
props: {
- disabledDate: {},
- date: {},
- year: {}
+ fixed: String,
+ store: {
+ required: true
+ },
+ layout: {
+ required: true
+ },
+ summaryMethod: Function,
+ sumText: String,
+ border: Boolean,
+ defaultSort: {
+ type: Object,
+ default: function _default() {
+ return {
+ prop: '',
+ order: ''
+ };
+ }
+ }
},
computed: {
- startYear: function startYear() {
- return Math.floor(this.year / 10) * 10;
+ isAllSelected: function isAllSelected() {
+ return this.store.states.isAllSelected;
+ },
+ columnsCount: function columnsCount() {
+ return this.store.states.columns.length;
+ },
+ leftFixedCount: function leftFixedCount() {
+ return this.store.states.fixedColumns.length;
+ },
+ rightFixedCount: function rightFixedCount() {
+ return this.store.states.rightFixedColumns.length;
+ },
+ columns: function columns() {
+ return this.store.states.columns;
}
},
methods: {
- getCellStyle: function getCellStyle(year) {
- var style = {};
-
- var date = new Date(0);
- date.setFullYear(year);
- date.setHours(0);
- var nextYear = new Date(date);
- nextYear.setFullYear(year + 1);
-
- var flag = false;
- if (typeof this.disabledDate === 'function') {
-
- while (date < nextYear) {
- if (this.disabledDate(date)) {
- date = new Date(date.getTime() + 8.64e7);
- } else {
- break;
- }
+ isCellHidden: function isCellHidden(index, columns) {
+ if (this.fixed === true || this.fixed === 'left') {
+ return index >= this.leftFixedCount;
+ } else if (this.fixed === 'right') {
+ var before = 0;
+ for (var i = 0; i < index; i++) {
+ before += columns[i].colSpan;
}
- if (date - nextYear === 0) flag = true;
+ return before < this.columnsCount - this.rightFixedCount;
+ } else {
+ return index < this.leftFixedCount || index >= this.columnsCount - this.rightFixedCount;
}
+ }
+ }
+ };
- style.disabled = flag;
- style.current = Number(this.year) === year;
+/***/ },
+/* 146 */
+/***/ function(module, exports) {
- return style;
- },
- nextTenYear: function nextTenYear() {
- this.$emit('pick', Number(this.year) + 10, false);
+ module.exports={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,
+ 'el-table--hidden': _vm.isHidden,
+ 'el-table--fluid-height': _vm.maxHeight,
+ '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
},
- prevTenYear: function prevTenYear() {
- this.$emit('pick', Number(this.year) - 10, false);
- },
- handleYearTableClick: function handleYearTableClick(event) {
- var target = event.target;
- if (target.tagName === 'A') {
- if ((0, _dom.hasClass)(target.parentNode, 'disabled')) return;
- var year = target.textContent || target.innerText;
- this.$emit('pick', Number(year));
+ on: {
+ "mouseleave": function($event) {
+ _vm.handleMouseLeave($event)
}
}
- }
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
-
-/***/ },
-/* 166 */
-/***/ function(module, exports) {
-
- module.exports={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('div', {
+ ref: "hiddenColumns",
+ staticClass: "hidden-columns"
+ }, [_vm._t("default")], 2), (_vm.showHeader) ? _c('div', {
+ ref: "headerWrapper",
+ staticClass: "el-table__header-wrapper"
+ }, [_c('table-header', {
+ style: ({
+ width: _vm.layout.bodyWidth ? _vm.layout.bodyWidth + 'px' : ''
+ }),
+ attrs: {
+ "store": _vm.store,
+ "layout": _vm.layout,
+ "border": _vm.border,
+ "default-sort": _vm.defaultSort
}
- }, [_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')])])])
+ })], 1) : _vm._e(), _c('div', {
+ ref: "bodyWrapper",
+ staticClass: "el-table__body-wrapper",
+ style: ([_vm.bodyHeight])
+ }, [_c('table-body', {
+ style: ({
+ width: _vm.bodyWidth
+ }),
+ attrs: {
+ "context": _vm.context,
+ "store": _vm.store,
+ "stripe": _vm.stripe,
+ "layout": _vm.layout,
+ "row-class-name": _vm.rowClassName,
+ "row-style": _vm.rowStyle,
+ "highlight": _vm.highlightCurrentRow
+ }
+ }), (!_vm.data || _vm.data.length === 0) ? _c('div', {
+ staticClass: "el-table__empty-block",
+ style: ({
+ width: _vm.bodyWidth
+ })
+ }, [_c('span', {
+ staticClass: "el-table__empty-text"
+ }, [_vm._t("empty", [_vm._v(_vm._s(_vm.emptyText || _vm.t('el.table.emptyText')))])], 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"
+ }],
+ ref: "footerWrapper",
+ staticClass: "el-table__footer-wrapper"
+ }, [_c('table-footer', {
+ style: ({
+ width: _vm.layout.bodyWidth ? _vm.layout.bodyWidth + 'px' : ''
+ }),
+ attrs: {
+ "store": _vm.store,
+ "layout": _vm.layout,
+ "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', {
+ 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', {
+ style: ({
+ width: _vm.layout.fixedWidth ? _vm.layout.fixedWidth + 'px' : ''
+ }),
+ attrs: {
+ "fixed": "left",
+ "border": _vm.border,
+ "store": _vm.store,
+ "layout": _vm.layout
+ }
+ })], 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.layout.fixedWidth ? _vm.layout.fixedWidth + 'px' : ''
+ }),
+ attrs: {
+ "fixed": "left",
+ "store": _vm.store,
+ "stripe": _vm.stripe,
+ "layout": _vm.layout,
+ "highlight": _vm.highlightCurrentRow,
+ "row-class-name": _vm.rowClassName,
+ "row-style": _vm.rowStyle
+ }
+ })], 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.layout.fixedWidth ? _vm.layout.fixedWidth + 'px' : ''
+ }),
+ attrs: {
+ "fixed": "left",
+ "border": _vm.border,
+ "sum-text": _vm.sumText || _vm.t('el.table.sumText'),
+ "summary-method": _vm.summaryMethod,
+ "store": _vm.store,
+ "layout": _vm.layout
+ }
+ })], 1) : _vm._e()]) : _vm._e(), (_vm.rightFixedColumns.length > 0) ? _c('div', {
+ 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 || 1)) + 'px' : ''
+ },
+ _vm.fixedHeight
+ ])
+ }, [(_vm.showHeader) ? _c('div', {
+ ref: "rightFixedHeaderWrapper",
+ staticClass: "el-table__fixed-header-wrapper"
+ }, [_c('table-header', {
+ style: ({
+ width: _vm.layout.rightFixedWidth ? _vm.layout.rightFixedWidth + 'px' : ''
+ }),
+ attrs: {
+ "fixed": "right",
+ "border": _vm.border,
+ "store": _vm.store,
+ "layout": _vm.layout
+ }
+ })], 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.layout.rightFixedWidth ? _vm.layout.rightFixedWidth + 'px' : ''
+ }),
+ attrs: {
+ "fixed": "right",
+ "store": _vm.store,
+ "stripe": _vm.stripe,
+ "layout": _vm.layout,
+ "row-class-name": _vm.rowClassName,
+ "row-style": _vm.rowStyle,
+ "highlight": _vm.highlightCurrentRow
+ }
+ })], 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.layout.rightFixedWidth ? _vm.layout.rightFixedWidth + 'px' : ''
+ }),
+ attrs: {
+ "fixed": "right",
+ "border": _vm.border,
+ "sum-text": _vm.sumText || _vm.t('el.table.sumText'),
+ "summary-method": _vm.summaryMethod,
+ "store": _vm.store,
+ "layout": _vm.layout
+ }
+ })], 1) : _vm._e()]) : _vm._e(), (_vm.rightFixedColumns.length > 0) ? _c('div', {
+ 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"
+ })])
},staticRenderFns: []}
/***/ },
-/* 167 */
+/* 147 */
/***/ function(module, exports, __webpack_require__) {
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(168),
- /* template */
- __webpack_require__(169),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ 'use strict';
- module.exports = Component.exports
+ exports.__esModule = true;
+
+ var _tableColumn = __webpack_require__(148);
+
+ var _tableColumn2 = _interopRequireDefault(_tableColumn);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _tableColumn2.default.install = function (Vue) {
+ Vue.component(_tableColumn2.default.name, _tableColumn2.default);
+ };
+ exports.default = _tableColumn2.default;
/***/ },
-/* 168 */
+/* 148 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _locale = __webpack_require__(10);
-
- var _locale2 = _interopRequireDefault(_locale);
+ var _checkbox = __webpack_require__(130);
- var _dom = __webpack_require__(44);
+ var _checkbox2 = _interopRequireDefault(_checkbox);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _tag = __webpack_require__(109);
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ var _tag2 = _interopRequireDefault(_tag);
- exports.default = {
- props: {
- disabledDate: {},
- date: {},
- month: {
- type: Number
- }
- },
- mixins: [_locale2.default],
- methods: {
- getCellStyle: function getCellStyle(month) {
- var style = {};
+ var _merge = __webpack_require__(64);
- var year = this.date.getFullYear();
- var date = new Date(0);
- date.setFullYear(year);
- date.setMonth(month);
- date.setHours(0);
- var nextMonth = new Date(date);
- nextMonth.setMonth(month + 1);
+ var _merge2 = _interopRequireDefault(_merge);
- var flag = false;
- if (typeof this.disabledDate === 'function') {
+ var _util = __webpack_require__(107);
- while (date < nextMonth) {
- if (this.disabledDate(date)) {
- date = new Date(date.getTime() + 8.64e7);
- flag = true;
- } else {
- flag = false;
- break;
- }
- }
- }
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- style.disabled = flag;
- style.current = this.month === month;
+ function _objectDestructuringEmpty(obj) { if (obj == null) throw new TypeError("Cannot destructure undefined"); }
- return style;
- },
- handleMonthTableClick: function handleMonthTableClick(event) {
- var target = event.target;
- if (target.tagName !== 'A') return;
- if ((0, _dom.hasClass)(target.parentNode, 'disabled')) return;
- var column = target.parentNode.cellIndex;
- var row = target.parentNode.parentNode.rowIndex;
- var month = row * 4 + column;
+ var columnIdSeed = 1;
- this.$emit('pick', month);
- }
+ var defaults = {
+ 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: ''
}
};
-/***/ },
-/* 169 */
-/***/ function(module, exports) {
+ var forced = {
+ selection: {
+ renderHeader: function renderHeader(h) {
+ return h(
+ 'el-checkbox',
+ {
+ nativeOn: {
+ 'click': this.toggleAllSelection
+ },
+ attrs: {
+ value: this.isAllSelected }
+ },
+ []
+ );
+ },
+ renderCell: function renderCell(h, _ref) {
+ var row = _ref.row,
+ column = _ref.column,
+ store = _ref.store,
+ $index = _ref.$index;
- module.exports={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
- }
- }, [_c('tbody', [_c('tr', [_c('td', {
- class: _vm.getCellStyle(0)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.jan')))])]), _c('td', {
- class: _vm.getCellStyle(1)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.feb')))])]), _c('td', {
- class: _vm.getCellStyle(2)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.mar')))])]), _c('td', {
- class: _vm.getCellStyle(3)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.apr')))])])]), _c('tr', [_c('td', {
- class: _vm.getCellStyle(4)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.may')))])]), _c('td', {
- class: _vm.getCellStyle(5)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.jun')))])]), _c('td', {
- class: _vm.getCellStyle(6)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.jul')))])]), _c('td', {
- class: _vm.getCellStyle(7)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.aug')))])])]), _c('tr', [_c('td', {
- class: _vm.getCellStyle(8)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.sep')))])]), _c('td', {
- class: _vm.getCellStyle(9)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.oct')))])]), _c('td', {
- class: _vm.getCellStyle(10)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.nov')))])]), _c('td', {
- class: _vm.getCellStyle(11)
- }, [_c('a', {
- staticClass: "cell"
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.dec')))])])])])])
- },staticRenderFns: []}
-
-/***/ },
-/* 170 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(171),
- /* template */
- __webpack_require__(172),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ return h(
+ 'el-checkbox',
+ {
+ 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, _ref2) {
+ var column = _ref2.column;
- module.exports = Component.exports
+ return column.label || '#';
+ },
+ renderCell: function renderCell(h, _ref3) {
+ var $index = _ref3.$index;
+ return h(
+ 'div',
+ null,
+ [$index + 1]
+ );
+ },
+ sortable: false
+ },
+ expand: {
+ renderHeader: function renderHeader(h, _ref4) {
+ _objectDestructuringEmpty(_ref4);
-/***/ },
-/* 171 */
-/***/ function(module, exports, __webpack_require__) {
+ return '';
+ },
+ renderCell: function renderCell(h, _ref5, proxy) {
+ var row = _ref5.row,
+ store = _ref5.store;
- 'use strict';
+ var expanded = store.states.expandRows.indexOf(row) > -1;
+ return h(
+ 'div',
+ { 'class': 'el-table__expand-icon ' + (expanded ? 'el-table__expand-icon--expanded' : ''),
+ on: {
+ 'click': function click() {
+ return proxy.handleExpandClick(row);
+ }
+ }
+ },
+ [h(
+ 'i',
+ { 'class': 'el-icon el-icon-arrow-right' },
+ []
+ )]
+ );
+ },
+ sortable: false,
+ resizable: false,
+ className: 'el-table__expand-column'
+ }
+ };
- exports.__esModule = true;
+ var getDefaultColumn = function getDefaultColumn(type, options) {
+ var column = {};
- var _util = __webpack_require__(153);
+ (0, _merge2.default)(column, defaults[type || 'default']);
- var _dom = __webpack_require__(44);
+ for (var name in options) {
+ if (options.hasOwnProperty(name)) {
+ var value = options[name];
+ if (typeof value !== 'undefined') {
+ column[name] = value;
+ }
+ }
+ }
- var _locale = __webpack_require__(10);
+ if (!column.minWidth) {
+ column.minWidth = 80;
+ }
- var _locale2 = _interopRequireDefault(_locale);
+ column.realWidth = column.width || column.minWidth;
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ return column;
+ };
- var _WEEKS = ['sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat']; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ var DEFAULT_RENDER_CELL = function DEFAULT_RENDER_CELL(h, _ref6) {
+ var row = _ref6.row,
+ column = _ref6.column;
- var clearHours = function clearHours(time) {
- var cloneDate = new Date(time);
- cloneDate.setHours(0, 0, 0, 0);
- return cloneDate.getTime();
+ var property = column.property;
+ var value = property && property.indexOf('.') === -1 ? row[property] : (0, _util.getValueByPath)(row, property);
+ if (column && column.formatter) {
+ return column.formatter(row, column, value);
+ }
+ return value;
};
exports.default = {
- mixins: [_locale2.default],
+ name: 'ElTableColumn',
props: {
- firstDayOfWeek: {
- default: 7,
- type: Number,
- validator: function validator(val) {
- return val >= 1 && val <= 7;
- }
+ type: {
+ type: String,
+ default: 'default'
},
-
- date: {},
-
- year: {},
-
- month: {},
-
- week: {},
-
- selectionMode: {
- default: 'day'
+ label: String,
+ className: String,
+ labelClassName: String,
+ property: String,
+ prop: String,
+ width: {},
+ minWidth: {},
+ renderHeader: Function,
+ sortable: {
+ type: [String, Boolean],
+ default: false
},
-
- showWeekNumber: {
+ sortMethod: Function,
+ resizable: {
type: Boolean,
- default: false
+ default: true
},
+ context: {},
+ 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
+ }
+ },
- disabledDate: {},
+ data: function data() {
+ return {
+ isSubColumn: false,
+ columns: []
+ };
+ },
+ beforeCreate: function beforeCreate() {
+ this.row = {};
+ this.column = {};
+ this.$index = 0;
+ },
- minDate: {},
- maxDate: {},
+ components: {
+ ElCheckbox: _checkbox2.default,
+ ElTag: _tag2.default
+ },
- rangeState: {
- default: function _default() {
- return {
- endDate: null,
- selecting: false,
- row: null,
- column: null
- };
+ computed: {
+ owner: function owner() {
+ var parent = this.$parent;
+ while (parent && !parent.tableId) {
+ parent = parent.$parent;
}
+ return parent;
}
},
- 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);
- },
- monthDate: function monthDate() {
- return this.date.getDate();
- },
- startDate: function startDate() {
- return (0, _util.getStartDateOfMonth)(this.year, this.month);
- },
- rows: function rows() {
- var date = new Date(this.year, this.month, 1);
- var day = (0, _util.getFirstDayOfMonth)(date); // day of first day
- var dateCountOfMonth = (0, _util.getDayCountOfMonth)(date.getFullYear(), date.getMonth());
- var dateCountOfLastMonth = (0, _util.getDayCountOfMonth)(date.getFullYear(), date.getMonth() === 0 ? 11 : date.getMonth() - 1);
+ created: function created() {
+ var _this = this;
- day = day === 0 ? 7 : day;
+ this.customRender = this.$options.render;
+ this.$options.render = function (h) {
+ return h('div', _this.$slots.default);
+ };
+ this.columnId = (this.$parent.tableId || this.$parent.columnId + '_') + 'column_' + columnIdSeed++;
- var offset = this.offsetDay;
- var rows = this.tableRows;
- var count = 1;
- var firstDayPosition = void 0;
+ var parent = this.$parent;
+ var owner = this.owner;
+ this.isSubColumn = owner !== parent;
- var startDate = this.startDate;
- var disabledDate = this.disabledDate;
- var now = clearHours(new Date());
+ var type = this.type;
- for (var i = 0; i < 6; i++) {
- var row = rows[i];
+ var width = this.width;
+ if (width !== undefined) {
+ width = parseInt(width, 10);
+ if (isNaN(width)) {
+ width = null;
+ }
+ }
- if (this.showWeekNumber) {
- if (!row[0]) {
- row[0] = { type: 'week', text: (0, _util.getWeekNumber)(new Date(startDate.getTime() + _util.DAY_DURATION * (i * 7 + 1))) };
- }
- }
+ var minWidth = this.minWidth;
+ if (minWidth !== undefined) {
+ minWidth = parseInt(minWidth, 10);
+ if (isNaN(minWidth)) {
+ minWidth = 80;
+ }
+ }
- for (var j = 0; j < 7; j++) {
- var cell = row[this.showWeekNumber ? j + 1 : j];
- if (!cell) {
- cell = { row: i, column: j, type: 'normal', inRange: false, start: false, end: false };
- }
+ var isColumnGroup = false;
- cell.type = 'normal';
+ var column = getDefaultColumn(type, {
+ id: this.columnId,
+ columnKey: this.columnKey,
+ label: this.label,
+ className: this.className,
+ labelClassName: this.labelClassName,
+ property: this.prop || this.property,
+ type: type,
+ renderCell: null,
+ renderHeader: this.renderHeader,
+ minWidth: minWidth,
+ width: width,
+ isColumnGroup: isColumnGroup,
+ context: this.context,
+ align: this.align ? 'is-' + this.align : null,
+ headerAlign: this.headerAlign ? 'is-' + this.headerAlign : this.align ? 'is-' + this.align : null,
+ sortable: this.sortable === '' ? true : this.sortable,
+ sortMethod: this.sortMethod,
+ resizable: this.resizable,
+ showOverflowTooltip: this.showOverflowTooltip || this.showTooltipWhenOverflow,
+ formatter: this.formatter,
+ selectable: this.selectable,
+ reserveSelection: this.reserveSelection,
+ fixed: this.fixed === '' ? true : this.fixed,
+ filterMethod: this.filterMethod,
+ filters: this.filters,
+ filterable: this.filters || this.filterMethod,
+ filterMultiple: this.filterMultiple,
+ filterOpened: false,
+ filteredValue: this.filteredValue || [],
+ filterPlacement: this.filterPlacement || ''
+ });
- var index = i * 7 + j;
- var time = startDate.getTime() + _util.DAY_DURATION * (index - offset);
- cell.inRange = time >= clearHours(this.minDate) && time <= clearHours(this.maxDate);
- cell.start = this.minDate && time === clearHours(this.minDate);
- cell.end = this.maxDate && time === clearHours(this.maxDate);
- var isToday = time === now;
+ (0, _merge2.default)(column, forced[type] || {});
- if (isToday) {
- cell.type = 'today';
- }
+ this.columnConfig = column;
- if (i >= 0 && i <= 1) {
- if (j + i * 7 >= day + offset) {
- cell.text = count++;
- if (count === 2) {
- firstDayPosition = i * 7 + j;
- }
- } else {
- cell.text = dateCountOfLastMonth - (day + offset - j % 7) + 1 + i * 7;
- cell.type = 'prev-month';
- }
- } else {
- if (count <= dateCountOfMonth) {
- cell.text = count++;
- if (count === 2) {
- firstDayPosition = i * 7 + j;
- }
- } else {
- cell.text = count++ - dateCountOfMonth;
- cell.type = 'next-month';
- }
- }
+ var renderCell = column.renderCell;
+ var _self = this;
- cell.disabled = typeof disabledDate === 'function' && disabledDate(new Date(time));
+ if (type === 'expand') {
+ owner.renderExpanded = function (h, data) {
+ return _self.$scopedSlots.default ? _self.$scopedSlots.default(data) : _self.$slots.default;
+ };
- this.$set(row, this.showWeekNumber ? j + 1 : j, cell);
- }
+ column.renderCell = function (h, data) {
+ return h(
+ 'div',
+ { 'class': 'cell' },
+ [renderCell(h, data, this._renderProxy)]
+ );
+ };
- if (this.selectionMode === 'week') {
- var start = this.showWeekNumber ? 1 : 0;
- var end = this.showWeekNumber ? 7 : 6;
- var isWeekActive = this.isWeekActive(row[start + 1]);
+ return;
+ }
- row[start].inRange = isWeekActive;
- row[start].start = isWeekActive;
- row[end].inRange = isWeekActive;
- row[end].end = isWeekActive;
- }
+ column.renderCell = function (h, data) {
+ // 未来版本移除
+ if (_self.$vnode.data.inlineTemplate) {
+ renderCell = function renderCell() {
+ data._self = _self.context || data._self;
+ if (Object.prototype.toString.call(data._self) === '[object Object]') {
+ for (var prop in data._self) {
+ if (!data.hasOwnProperty(prop)) {
+ data[prop] = data._self[prop];
+ }
+ }
+ }
+ // 静态内容会缓存到 _staticTrees 内,不改的话获取的静态数据就不是内部 context
+ data._staticTrees = _self._staticTrees;
+ data.$options.staticRenderFns = _self.$options.staticRenderFns;
+ return _self.customRender.call(data);
+ };
+ } else if (_self.$scopedSlots.default) {
+ renderCell = function renderCell() {
+ return _self.$scopedSlots.default(data);
+ };
}
- rows.firstDayPosition = firstDayPosition;
+ if (!renderCell) {
+ renderCell = DEFAULT_RENDER_CELL;
+ }
- return rows;
- }
+ return _self.showOverflowTooltip || _self.showTooltipWhenOverflow ? h(
+ 'div',
+ { 'class': 'cell el-tooltip', style: 'width:' + (data.column.realWidth || data.column.width) + 'px' },
+ [renderCell(h, data)]
+ ) : h(
+ 'div',
+ { 'class': 'cell' },
+ [renderCell(h, data)]
+ );
+ };
+ },
+ destroyed: function destroyed() {
+ if (!this.$parent) return;
+ this.owner.store.commit('removeColumn', this.columnConfig);
},
+
watch: {
- 'rangeState.endDate': function rangeStateEndDate(newVal) {
- this.markRange(newVal);
+ label: function label(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.label = newVal;
+ }
},
- minDate: function minDate(newVal, oldVal) {
- if (newVal && !oldVal) {
- this.rangeState.selecting = true;
- this.markRange(newVal);
- } else if (!newVal) {
- this.rangeState.selecting = false;
- this.markRange(newVal);
- } else {
- this.markRange();
+ prop: function prop(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.property = newVal;
}
},
- maxDate: function maxDate(newVal, oldVal) {
- if (newVal && !oldVal) {
- this.rangeState.selecting = false;
- this.markRange(newVal);
- this.$emit('pick', {
- minDate: this.minDate,
- maxDate: this.maxDate
- });
+ property: function property(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.property = newVal;
+ }
+ },
+ filters: function filters(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.filters = newVal;
+ }
+ },
+ filterMultiple: function filterMultiple(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.filterMultiple = newVal;
+ }
+ },
+ align: function align(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.align = newVal ? 'is-' + newVal : null;
+
+ if (!this.headerAlign) {
+ this.columnConfig.headerAlign = newVal ? 'is-' + newVal : null;
+ }
+ }
+ },
+ headerAlign: function headerAlign(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.headerAlign = 'is-' + (newVal ? newVal : this.align);
+ }
+ },
+ width: function width(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.width = newVal;
+ this.owner.store.scheduleLayout();
+ }
+ },
+ minWidth: function minWidth(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.minWidth = newVal;
+ this.owner.store.scheduleLayout();
+ }
+ },
+ fixed: function fixed(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.fixed = newVal;
+ this.owner.store.scheduleLayout();
+ }
+ },
+ sortable: function sortable(newVal) {
+ if (this.columnConfig) {
+ this.columnConfig.sortable = newVal;
}
}
},
- data: function data() {
- return {
- tableRows: [[], [], [], [], [], []]
- };
- },
+ mounted: function mounted() {
+ var owner = this.owner;
+ var parent = this.$parent;
+ var columnIndex = void 0;
+ if (!this.isSubColumn) {
+ columnIndex = [].indexOf.call(parent.$refs.hiddenColumns.children, this.$el);
+ } else {
+ columnIndex = [].indexOf.call(parent.$el.children, this.$el);
+ }
- methods: {
- getCellClasses: function getCellClasses(cell) {
- var selectionMode = this.selectionMode;
- var monthDate = this.monthDate;
+ owner.store.commit('insertColumn', this.columnConfig, columnIndex, this.isSubColumn ? parent.columnConfig : null);
+ }
+ };
- 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);
- }
+/***/ },
+/* 149 */
+/***/ function(module, exports, __webpack_require__) {
- if (selectionMode === 'day' && (cell.type === 'normal' || cell.type === 'today') && Number(this.year) === this.date.getFullYear() && this.month === this.date.getMonth() && monthDate === Number(cell.text)) {
- classes.push('current');
- }
+ 'use strict';
- if (cell.inRange && (cell.type === 'normal' || cell.type === 'today' || this.selectionMode === 'week')) {
- classes.push('in-range');
+ exports.__esModule = true;
- if (cell.start) {
- classes.push('start-date');
- }
+ var _datePicker = __webpack_require__(150);
- if (cell.end) {
- classes.push('end-date');
- }
- }
+ var _datePicker2 = _interopRequireDefault(_datePicker);
- if (cell.disabled) {
- classes.push('disabled');
- }
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- return classes.join(' ');
- },
- getDateOfCell: function getDateOfCell(row, column) {
- var startDate = this.startDate;
+ /* istanbul ignore next */
+ _datePicker2.default.install = function install(Vue) {
+ Vue.component(_datePicker2.default.name, _datePicker2.default);
+ };
- return new Date(startDate.getTime() + (row * 7 + (column - (this.showWeekNumber ? 1 : 0)) - this.offsetDay) * _util.DAY_DURATION);
- },
- getCellByDate: function getCellByDate(date) {
- var startDate = this.startDate;
- var rows = this.rows;
- var index = (date - startDate) / _util.DAY_DURATION;
- var row = rows[Math.floor(index / 7)];
+ exports.default = _datePicker2.default;
- if (this.showWeekNumber) {
- return row[index % 7 + 1];
- } else {
- return row[index % 7];
- }
- },
- 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();
+/***/ },
+/* 150 */
+/***/ function(module, exports, __webpack_require__) {
- if (cell.type === 'prev-month') {
- newDate.setMonth(month === 0 ? 11 : month - 1);
- newDate.setFullYear(month === 0 ? year - 1 : year);
- }
+ 'use strict';
- if (cell.type === 'next-month') {
- newDate.setMonth(month === 11 ? 0 : month + 1);
- newDate.setFullYear(month === 11 ? year + 1 : year);
- }
+ exports.__esModule = true;
- newDate.setDate(parseInt(cell.text, 10));
+ var _picker = __webpack_require__(151);
- return (0, _util.getWeekNumber)(newDate) === this.week;
- },
- markRange: function markRange(maxDate) {
- var startDate = this.startDate;
- if (!maxDate) {
- maxDate = this.maxDate;
- }
+ var _picker2 = _interopRequireDefault(_picker);
- var rows = this.rows;
- var minDate = this.minDate;
- 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 _date = __webpack_require__(156);
- var cell = row[j];
- var index = i * 7 + j + (this.showWeekNumber ? -1 : 0);
- var time = startDate.getTime() + _util.DAY_DURATION * (index - this.offsetDay);
+ var _date2 = _interopRequireDefault(_date);
- cell.inRange = minDate && time >= clearHours(minDate) && time <= clearHours(maxDate);
- cell.start = minDate && time === clearHours(minDate.getTime());
- cell.end = maxDate && time === clearHours(maxDate.getTime());
- }
- }
- },
- handleMouseMove: function handleMouseMove(event) {
- if (!this.rangeState.selecting) return;
+ var _dateRange = __webpack_require__(174);
- this.$emit('changerange', {
- minDate: this.minDate,
- maxDate: this.maxDate,
- rangeState: this.rangeState
- });
+ var _dateRange2 = _interopRequireDefault(_dateRange);
- var target = event.target;
- if (target.tagName !== 'TD') return;
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var column = target.cellIndex;
- var row = target.parentNode.rowIndex - 1;
- var _rangeState = this.rangeState,
- oldRow = _rangeState.row,
- oldColumn = _rangeState.column;
+ var getPanel = function getPanel(type) {
+ if (type === 'daterange' || type === 'datetimerange') {
+ return _dateRange2.default;
+ }
+ return _date2.default;
+ };
+ exports.default = {
+ mixins: [_picker2.default],
- if (oldRow !== row || oldColumn !== column) {
- this.rangeState.row = row;
- this.rangeState.column = column;
+ name: 'ElDatePicker',
- this.rangeState.endDate = this.getDateOfCell(row, column);
+ props: {
+ type: {
+ type: String,
+ default: 'date'
+ }
+ },
+
+ watch: {
+ type: function type(_type) {
+ if (this.picker) {
+ this.unmountPicker();
+ this.panel = getPanel(_type);
+ this.mountPicker();
+ } else {
+ this.panel = getPanel(_type);
}
- },
- handleClick: function handleClick(event) {
- var target = event.target;
+ }
+ },
- if (target.tagName !== 'TD') return;
- if ((0, _dom.hasClass)(target, 'disabled') || (0, _dom.hasClass)(target, 'week')) return;
+ created: function created() {
+ this.panel = getPanel(this.type);
+ }
+ };
- var selectionMode = this.selectionMode;
+/***/ },
+/* 151 */
+/***/ function(module, exports, __webpack_require__) {
- if (selectionMode === 'week') {
- target = target.parentNode.cells[1];
- }
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(152),
+ /* template */
+ __webpack_require__(155),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- var year = Number(this.year);
- var month = Number(this.month);
+ module.exports = Component.exports
- var cellIndex = target.cellIndex;
- var rowIndex = target.parentNode.rowIndex;
- var cell = this.rows[rowIndex - 1][cellIndex];
- var text = cell.text;
- var className = target.className;
+/***/ },
+/* 152 */
+/***/ function(module, exports, __webpack_require__) {
- var newDate = new Date(year, month, 1);
+ 'use strict';
- if (className.indexOf('prev') !== -1) {
- if (month === 0) {
- year = year - 1;
- month = 11;
- } else {
- month = month - 1;
- }
- newDate.setFullYear(year);
- newDate.setMonth(month);
- } else if (className.indexOf('next') !== -1) {
- if (month === 11) {
- year = year + 1;
- month = 0;
- } else {
- month = month + 1;
- }
- newDate.setFullYear(year);
- newDate.setMonth(month);
- }
+ exports.__esModule = true;
- newDate.setDate(parseInt(text, 10));
+ var _vue = __webpack_require__(133);
- if (this.selectionMode === 'range') {
- if (this.minDate && this.maxDate) {
- var minDate = new Date(newDate.getTime());
- var maxDate = null;
+ var _vue2 = _interopRequireDefault(_vue);
- this.$emit('pick', { minDate: minDate, maxDate: maxDate }, false);
- this.rangeState.selecting = true;
- this.markRange(this.minDate);
- } else if (this.minDate && !this.maxDate) {
- if (newDate >= this.minDate) {
- var _maxDate = new Date(newDate.getTime());
- this.rangeState.selecting = false;
+ var _clickoutside = __webpack_require__(21);
- this.$emit('pick', {
- minDate: this.minDate,
- maxDate: _maxDate
- });
- } else {
- var _minDate = new Date(newDate.getTime());
+ var _clickoutside2 = _interopRequireDefault(_clickoutside);
- this.$emit('pick', { minDate: _minDate, maxDate: this.maxDate }, false);
- }
- } else if (!this.minDate) {
- var _minDate2 = new Date(newDate.getTime());
+ var _util = __webpack_require__(153);
- this.$emit('pick', { minDate: _minDate2, maxDate: this.maxDate }, false);
- this.rangeState.selecting = true;
- this.markRange(this.minDate);
- }
- } else if (selectionMode === 'day') {
- this.$emit('pick', newDate);
- } else if (selectionMode === 'week') {
- var weekNumber = (0, _util.getWeekNumber)(newDate);
+ var _vuePopper = __webpack_require__(24);
- var value = newDate.getFullYear() + 'w' + weekNumber;
- this.$emit('pick', {
- year: newDate.getFullYear(),
- week: weekNumber,
- value: value,
- date: newDate
- });
- }
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
+
+ var _emitter = __webpack_require__(15);
+
+ var _emitter2 = _interopRequireDefault(_emitter);
+
+ var _input = __webpack_require__(20);
+
+ var _input2 = _interopRequireDefault(_input);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+ var NewPopper = {
+ props: {
+ appendToBody: _vuePopper2.default.props.appendToBody,
+ offset: _vuePopper2.default.props.offset,
+ boundariesPadding: _vuePopper2.default.props.boundariesPadding
+ },
+ methods: _vuePopper2.default.methods,
+ data: _vuePopper2.default.data,
+ beforeDestroy: _vuePopper2.default.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',
+ datetimerange: 'yyyy-MM-dd HH:mm:ss',
+ year: 'yyyy'
+ };
+ var HAVE_TRIGGER_TYPES = ['date', 'datetime', 'time', 'time-select', 'week', 'month', 'year', 'daterange', 'timerange', 'datetimerange'];
+ var DATE_FORMATTER = function DATE_FORMATTER(value, format) {
+ return (0, _util.formatDate)(value, format);
+ };
+ var DATE_PARSER = function DATE_PARSER(text, format) {
+ return (0, _util.parseDate)(text, format);
+ };
+ var RANGE_FORMATTER = function RANGE_FORMATTER(value, format, separator) {
+ if (Array.isArray(value) && value.length === 2) {
+ var start = value[0];
+ var end = value[1];
+
+ if (start && end) {
+ return (0, _util.formatDate)(start, format) + separator + (0, _util.formatDate)(end, format);
}
}
+ return '';
};
+ var RANGE_PARSER = function RANGE_PARSER(text, format, separator) {
+ var array = text.split(separator);
+ if (array.length === 2) {
+ var range1 = array[0];
+ var range2 = array[1];
-/***/ },
-/* 172 */
-/***/ function(module, exports) {
-
- module.exports={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"
+ return [(0, _util.parseDate)(range1, format), (0, _util.parseDate)(range2, format)];
+ }
+ return [];
+ };
+ var TYPE_VALUE_RESOLVER_MAP = {
+ default: {
+ formatter: function formatter(value) {
+ if (!value) return '';
+ return '' + value;
},
- on: {
- "click": _vm.handleClick,
- "mousemove": _vm.handleMouseMove
+ parser: function parser(text) {
+ if (text === undefined || text === '') return null;
+ return text;
}
- }, [_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) {
- return _c('th', [_vm._v(_vm._s(_vm.t('el.datepicker.weeks.' + week)))])
- })], 2), _vm._l((_vm.rows), function(row) {
- return _c('tr', {
- staticClass: "el-date-table__row",
- class: {
- current: _vm.isWeekActive(row[1])
- }
- }, _vm._l((row), function(cell) {
- return _c('td', {
- class: _vm.getCellClasses(cell),
- domProps: {
- "textContent": _vm._s(cell.type === 'today' ? _vm.t('el.datepicker.today') : cell.text)
- }
- })
- }))
- })], 2)])
- },staticRenderFns: []}
-
-/***/ },
-/* 173 */
-/***/ function(module, exports) {
+ },
+ week: {
+ formatter: function formatter(value, format) {
+ var date = (0, _util.formatDate)(value, format);
+ var week = (0, _util.getWeekNumber)(value);
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('transition', {
- attrs: {
- "name": "el-zoom-in-top"
+ date = /WW/.test(date) ? date.replace(/WW/, week < 10 ? '0' + week : week) : date.replace(/W/, week);
+ return date;
},
- 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-picker",
- class: [{
- 'has-sidebar': _vm.$slots.sidebar || _vm.shortcuts,
- 'has-time': _vm.showTime
- }, _vm.popperClass],
- style: ({
- width: _vm.width + 'px'
- })
- }, [_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) {
- return _c('button', {
- staticClass: "el-picker-panel__shortcut",
- attrs: {
- "type": "button"
- },
- on: {
- "click": function($event) {
- _vm.handleShortcutClick(shortcut)
+ parser: function parser(text) {
+ var array = (text || '').split('w');
+ if (array.length === 2) {
+ var year = Number(array[0]);
+ var month = Number(array[1]);
+
+ if (!isNaN(year) && !isNaN(month) && month < 54) {
+ return text;
}
}
- }, [_vm._v(_vm._s(shortcut.text))])
- })) : _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"
+ return null;
+ }
+ },
+ date: {
+ formatter: DATE_FORMATTER,
+ parser: DATE_PARSER
+ },
+ datetime: {
+ formatter: DATE_FORMATTER,
+ parser: DATE_PARSER
+ },
+ daterange: {
+ formatter: RANGE_FORMATTER,
+ parser: RANGE_PARSER
+ },
+ datetimerange: {
+ formatter: RANGE_FORMATTER,
+ parser: RANGE_PARSER
+ },
+ timerange: {
+ formatter: RANGE_FORMATTER,
+ parser: RANGE_PARSER
+ },
+ time: {
+ formatter: DATE_FORMATTER,
+ parser: DATE_PARSER
+ },
+ month: {
+ formatter: DATE_FORMATTER,
+ parser: DATE_PARSER
+ },
+ year: {
+ formatter: DATE_FORMATTER,
+ parser: DATE_PARSER
+ },
+ number: {
+ formatter: function formatter(value) {
+ if (!value) return '';
+ return '' + value;
},
- nativeOn: {
- "change": function($event) {
- _vm.visibleDate = $event.target.value
+ parser: function parser(text) {
+ var result = Number(text);
+
+ if (!isNaN(text)) {
+ return result;
+ } else {
+ return null;
}
}
- })], 1), _c('span', {
- staticClass: "el-date-picker__editor-wrap"
- }, [_c('el-input', {
- ref: "input",
- attrs: {
- "placeholder": _vm.t('el.datepicker.selectTime'),
- "value": _vm.visibleTime,
- "size": "small"
+ }
+ };
+ var PLACEMENT_MAP = {
+ left: 'bottom-start',
+ center: 'bottom',
+ right: 'bottom-end'
+ };
+
+ // only considers date-picker's value: Date or [Date, Date]
+ var valueEquals = function valueEquals(a, b) {
+ var aIsArray = a instanceof Array;
+ var bIsArray = b instanceof Array;
+ if (aIsArray && bIsArray) {
+ return new Date(a[0]).getTime() === new Date(b[0]).getTime() && new Date(a[1]).getTime() === new Date(b[1]).getTime();
+ }
+ if (!aIsArray && !bIsArray) {
+ return new Date(a).getTime() === new Date(b).getTime();
+ }
+ return false;
+ };
+
+ exports.default = {
+ mixins: [_emitter2.default, NewPopper],
+
+ props: {
+ size: String,
+ format: String,
+ readonly: Boolean,
+ placeholder: String,
+ disabled: Boolean,
+ clearable: {
+ type: Boolean,
+ default: true
},
- on: {
- "focus": function($event) {
- _vm.timePickerVisible = !_vm.timePickerVisible
- }
+ popperClass: String,
+ editable: {
+ type: Boolean,
+ default: true
},
- nativeOn: {
- "change": function($event) {
- _vm.visibleTime = $event.target.value
- }
- }
- }), _c('time-picker', {
- ref: "timepicker",
- attrs: {
- "date": _vm.date,
- "picker-width": _vm.pickerWidth,
- "visible": _vm.timePickerVisible
+ align: {
+ type: String,
+ default: 'left'
},
- on: {
- "pick": _vm.handleTimePick,
- "mounted": function($event) {
- _vm.$refs.timepicker.format = _vm.timeFormat
- }
- }
- })], 1)]) : _vm._e(), _c('div', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.currentView !== 'time'),
- expression: "currentView !== 'time'"
- }],
- staticClass: "el-date-picker__header"
- }, [_c('button', {
- staticClass: "el-picker-panel__icon-btn el-date-picker__prev-btn el-icon-d-arrow-left",
- attrs: {
- "type": "button"
+ value: {},
+ defaultValue: {},
+ rangeSeparator: {
+ default: ' - '
},
- 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"
+ pickerOptions: {}
+ },
+
+ components: { ElInput: _input2.default },
+
+ directives: { Clickoutside: _clickoutside2.default },
+
+ data: function data() {
+ return {
+ pickerVisible: false,
+ showClose: false,
+ currentValue: '',
+ unwatchPickerOptions: null
+ };
+ },
+
+
+ watch: {
+ pickerVisible: function pickerVisible(val) {
+ if (!val) this.dispatch('ElFormItem', 'el.form.blur');
+ if (this.readonly || this.disabled) return;
+ val ? this.showPicker() : this.hidePicker();
},
- on: {
- "click": _vm.prevMonth
- }
- }), _c('span', {
- staticClass: "el-date-picker__header-label",
- 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'
+ currentValue: function currentValue(val) {
+ if (val) return;
+ if (this.picker && typeof this.picker.handleClear === 'function') {
+ this.picker.handleClear();
+ } else {
+ this.$emit('input');
+ }
},
- 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"
+
+ value: {
+ immediate: true,
+ handler: function handler(val) {
+ this.currentValue = (0, _util.isDate)(val) ? new Date(val) : val;
+ }
},
- on: {
- "click": _vm.nextYear
+ displayValue: function displayValue(val) {
+ this.$emit('change', val);
+ this.dispatch('ElFormItem', 'el.form.change');
}
- }), _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"
+ },
+
+ computed: {
+ reference: function reference() {
+ return this.$refs.reference.$el;
},
- 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: {
- "year": _vm.year,
- "month": _vm.month,
- "date": _vm.date,
- "week": _vm.week,
- "selection-mode": _vm.selectionMode,
- "first-day-of-week": _vm.firstDayOfWeek,
- "disabled-date": _vm.disabledDate
+ refInput: function refInput() {
+ if (this.reference) return this.reference.querySelector('input');
+ return {};
},
- on: {
- "pick": _vm.handleDatePick
- }
- }), _c('year-table', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.currentView === 'year'),
- expression: "currentView === 'year'"
- }],
- ref: "yearTable",
- attrs: {
- "year": _vm.year,
- "date": _vm.date,
- "disabled-date": _vm.disabledDate
+ valueIsEmpty: function valueIsEmpty() {
+ var val = this.currentValue;
+ 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;
},
- on: {
- "pick": _vm.handleYearPick
- }
- }), _c('month-table', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.currentView === 'month'),
- expression: "currentView === 'month'"
- }],
- attrs: {
- "month": _vm.month,
- "date": _vm.date,
- "disabled-date": _vm.disabledDate
+ triggerClass: function triggerClass() {
+ return this.type.indexOf('time') !== -1 ? 'el-icon-time' : 'el-icon-date';
},
- 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('a', {
- staticClass: "el-picker-panel__link-btn",
- attrs: {
- "href": "JavaScript:"
+ selectionMode: function selectionMode() {
+ if (this.type === 'week') {
+ return 'week';
+ } else if (this.type === 'month') {
+ return 'month';
+ } else if (this.type === 'year') {
+ return 'year';
+ }
+
+ return 'day';
},
- on: {
- "click": _vm.changeToNow
- }
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.now')))]), _c('button', {
- staticClass: "el-picker-panel__btn",
- attrs: {
- "type": "button"
+ haveTrigger: function haveTrigger() {
+ if (typeof this.showTrigger !== 'undefined') {
+ return this.showTrigger;
+ }
+ return HAVE_TRIGGER_TYPES.indexOf(this.type) !== -1;
},
- on: {
- "click": _vm.confirm
- }
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.confirm')))])])])])
- },staticRenderFns: []}
-/***/ },
-/* 174 */
-/***/ function(module, exports, __webpack_require__) {
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(175),
- /* template */
- __webpack_require__(176),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ displayValue: {
+ get: function get() {
+ var value = this.currentValue;
+ if (!value) return;
+ var formatter = (TYPE_VALUE_RESOLVER_MAP[this.type] || TYPE_VALUE_RESOLVER_MAP['default']).formatter;
+ var format = DEFAULT_FORMATS[this.type];
- module.exports = Component.exports
+ return formatter(value, this.format || format, this.rangeSeparator);
+ },
+ set: function set(value) {
+ if (value) {
+ var type = this.type;
+ var parser = (TYPE_VALUE_RESOLVER_MAP[type] || TYPE_VALUE_RESOLVER_MAP['default']).parser;
+ var parsedValue = parser(value, this.format || DEFAULT_FORMATS[type], this.rangeSeparator);
+ if (parsedValue && this.picker) {
+ this.picker.value = parsedValue;
+ }
+ } else {
+ this.$emit('input', value);
+ this.picker.value = value;
+ }
+ this.$forceUpdate();
+ }
+ }
+ },
-/***/ },
-/* 175 */
-/***/ function(module, exports, __webpack_require__) {
+ created: function created() {
+ // vue-popper
+ this.popperOptions = {
+ boundariesPadding: 0,
+ gpuAcceleration: false
+ };
+ this.placement = PLACEMENT_MAP[this.align] || PLACEMENT_MAP.left;
+ },
- 'use strict';
- exports.__esModule = true;
+ methods: {
+ handleMouseEnterIcon: function handleMouseEnterIcon() {
+ if (this.readonly || this.disabled) return;
+ if (!this.valueIsEmpty && this.clearable) {
+ this.showClose = true;
+ }
+ },
+ handleClickIcon: function handleClickIcon() {
+ if (this.readonly || this.disabled) return;
+ if (this.showClose) {
+ this.currentValue = this.$options.defaultValue || '';
+ this.showClose = false;
+ } else {
+ this.pickerVisible = !this.pickerVisible;
+ }
+ },
+ dateChanged: function dateChanged(dateA, dateB) {
+ if (Array.isArray(dateA)) {
+ var len = dateA.length;
+ if (!dateB) return true;
+ while (len--) {
+ if (!(0, _util.equalDate)(dateA[len], dateB[len])) return true;
+ }
+ } else {
+ if (!(0, _util.equalDate)(dateA, dateB)) return true;
+ }
- var _util = __webpack_require__(153);
+ return false;
+ },
+ handleClose: function handleClose() {
+ this.pickerVisible = false;
+ },
+ handleFocus: function handleFocus() {
+ var type = this.type;
- var _locale = __webpack_require__(10);
+ if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) {
+ this.pickerVisible = true;
+ }
+ this.$emit('focus', this);
+ },
+ handleBlur: function handleBlur() {
+ this.$emit('blur', this);
+ },
+ handleKeydown: function handleKeydown(event) {
+ var keyCode = event.keyCode;
- var _locale2 = _interopRequireDefault(_locale);
+ // TAB or ESC
+ if (keyCode === 9 || keyCode === 27) {
+ this.pickerVisible = false;
+ event.stopPropagation();
+ }
+ },
+ hidePicker: function hidePicker() {
+ if (this.picker) {
+ this.picker.resetView && this.picker.resetView();
+ this.pickerVisible = this.picker.visible = false;
+ this.destroyPopper();
+ }
+ },
+ showPicker: function showPicker() {
+ var _this = this;
- var _time = __webpack_require__(158);
+ if (this.$isServer) return;
+ if (!this.picker) {
+ this.mountPicker();
+ }
+ this.pickerVisible = this.picker.visible = true;
- var _time2 = _interopRequireDefault(_time);
+ this.updatePopper();
- var _dateTable = __webpack_require__(170);
+ if (this.currentValue instanceof Date) {
+ this.picker.date = new Date(this.currentValue.getTime());
+ } else {
+ this.picker.value = this.currentValue;
+ }
+ this.picker.resetView && this.picker.resetView();
- var _dateTable2 = _interopRequireDefault(_dateTable);
+ this.$nextTick(function () {
+ _this.picker.ajustScrollTop && _this.picker.ajustScrollTop();
+ });
+ },
+ mountPicker: function mountPicker() {
+ var _this2 = this;
- var _input = __webpack_require__(20);
+ this.panel.defaultValue = this.defaultValue || this.currentValue;
+ this.picker = new _vue2.default(this.panel).$mount();
+ 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;
+ if (this.format) {
+ this.picker.format = this.format;
+ }
- var _input2 = _interopRequireDefault(_input);
+ var updateOptions = function updateOptions() {
+ var options = _this2.pickerOptions;
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ if (options && options.selectableRange) {
+ (function () {
+ var ranges = options.selectableRange;
+ var parser = TYPE_VALUE_RESOLVER_MAP.datetimerange.parser;
+ var format = DEFAULT_FORMATS.timerange;
- exports.default = {
- mixins: [_locale2.default],
+ ranges = Array.isArray(ranges) ? ranges : [ranges];
+ _this2.picker.selectableRange = ranges.map(function (range) {
+ return parser(range, format, _this2.rangeSeparator);
+ });
+ })();
+ }
- computed: {
- btnDisabled: function btnDisabled() {
- return !(this.minDate && this.maxDate && !this.selecting);
- },
- leftLabel: function leftLabel() {
- return this.date.getFullYear() + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + (this.date.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.date.getFullYear();
- },
- leftMonth: function leftMonth() {
- return this.date.getMonth();
- },
- rightYear: function rightYear() {
- return this.rightDate.getFullYear();
- },
- rightMonth: function rightMonth() {
- return this.rightDate.getMonth();
- },
- minVisibleDate: function minVisibleDate() {
- return this.minDate ? (0, _util.formatDate)(this.minDate) : '';
- },
- maxVisibleDate: function maxVisibleDate() {
- return this.maxDate || this.minDate ? (0, _util.formatDate)(this.maxDate || this.minDate) : '';
+ for (var option in options) {
+ if (options.hasOwnProperty(option) &&
+ // 忽略 time-picker 的该配置项
+ option !== 'selectableRange') {
+ _this2.picker[option] = options[option];
+ }
+ }
+ };
+ 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;
+
+ // do not emit if values are same
+ if (!valueEquals(_this2.value, date)) {
+ _this2.$emit('input', date);
+ }
+ _this2.pickerVisible = _this2.picker.visible = visible;
+ _this2.picker.resetView && _this2.picker.resetView();
+ });
+
+ this.picker.$on('select-range', function (start, end) {
+ _this2.refInput.setSelectionRange(start, end);
+ _this2.refInput.focus();
+ });
},
- minVisibleTime: function minVisibleTime() {
- return this.minDate ? (0, _util.formatDate)(this.minDate, 'HH:mm:ss') : '';
+ 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);
+ }
+ }
+ }
+ };
+
+/***/ },
+/* 153 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+ exports.limitRange = exports.getRangeHours = exports.nextMonth = exports.prevMonth = exports.getWeekNumber = exports.getStartDateOfMonth = exports.DAY_DURATION = exports.getFirstDayOfMonth = exports.getDayCountOfMonth = exports.parseDate = exports.formatDate = exports.isDate = exports.toDate = exports.equalDate = undefined;
+
+ var _date = __webpack_require__(154);
+
+ var _date2 = _interopRequireDefault(_date);
+
+ var _locale = __webpack_require__(111);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ var weeks = ['sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat'];
+ var months = ['jan', 'feb', 'mar', 'apr', 'may', 'jun', 'jul', 'aug', 'sep', 'oct', 'nov', 'dec'];
+ var getI18nSettings = function getI18nSettings() {
+ return {
+ dayNamesShort: weeks.map(function (week) {
+ return (0, _locale.t)('el.datepicker.weeks.' + week);
+ }),
+ dayNames: weeks.map(function (week) {
+ return (0, _locale.t)('el.datepicker.weeks.' + week);
+ }),
+ monthNamesShort: months.map(function (month) {
+ return (0, _locale.t)('el.datepicker.months.' + month);
+ }),
+ monthNames: months.map(function (month, index) {
+ return (0, _locale.t)('el.datepicker.month' + (index + 1));
+ }),
+ amPm: ['am', 'pm']
+ };
+ };
+
+ var newArray = function newArray(start, end) {
+ var result = [];
+ for (var i = start; i <= end; i++) {
+ result.push(i);
+ }
+ return result;
+ };
+
+ var equalDate = exports.equalDate = function equalDate(dateA, dateB) {
+ return dateA === dateB || new Date(dateA).getTime() === new Date(dateB).getTime();
+ };
+
+ var toDate = exports.toDate = function toDate(date) {
+ return isDate(date) ? new Date(date) : null;
+ };
+
+ var isDate = exports.isDate = function isDate(date) {
+ if (date === null || date === undefined) return false;
+ if (isNaN(new Date(date).getTime())) return false;
+ return true;
+ };
+
+ var formatDate = exports.formatDate = function formatDate(date, format) {
+ date = toDate(date);
+ if (!date) return '';
+ return _date2.default.format(date, format || 'yyyy-MM-dd', getI18nSettings());
+ };
+
+ var parseDate = exports.parseDate = function parseDate(string, format) {
+ return _date2.default.parse(string, format || 'yyyy-MM-dd', getI18nSettings());
+ };
+
+ var getDayCountOfMonth = exports.getDayCountOfMonth = function getDayCountOfMonth(year, month) {
+ if (month === 3 || month === 5 || month === 8 || month === 10) {
+ return 30;
+ }
+
+ if (month === 1) {
+ if (year % 4 === 0 && year % 100 !== 0 || year % 400 === 0) {
+ return 29;
+ } else {
+ return 28;
+ }
+ }
+
+ return 31;
+ };
+
+ var getFirstDayOfMonth = exports.getFirstDayOfMonth = function getFirstDayOfMonth(date) {
+ var temp = new Date(date.getTime());
+ temp.setDate(1);
+ return temp.getDay();
+ };
+
+ var DAY_DURATION = exports.DAY_DURATION = 86400000;
+
+ var getStartDateOfMonth = exports.getStartDateOfMonth = function getStartDateOfMonth(year, month) {
+ var result = new Date(year, month, 1);
+ var day = result.getDay();
+
+ if (day === 0) {
+ result.setTime(result.getTime() - DAY_DURATION * 7);
+ } else {
+ result.setTime(result.getTime() - DAY_DURATION * day);
+ }
+
+ return result;
+ };
+
+ var getWeekNumber = exports.getWeekNumber = function getWeekNumber(src) {
+ var date = new Date(src.getTime());
+ date.setHours(0, 0, 0, 0);
+ // Thursday in current week decides the year.
+ date.setDate(date.getDate() + 3 - (date.getDay() + 6) % 7);
+ // January 4 is always in week 1.
+ var week1 = new Date(date.getFullYear(), 0, 4);
+ // Adjust to Thursday in week 1 and count number of weeks from date to week 1.
+ return 1 + Math.round(((date.getTime() - week1.getTime()) / 86400000 - 3 + (week1.getDay() + 6) % 7) / 7);
+ };
+
+ var prevMonth = exports.prevMonth = function prevMonth(src) {
+ var year = src.getFullYear();
+ var month = src.getMonth();
+ var date = src.getDate();
+
+ var newYear = month === 0 ? year - 1 : year;
+ var newMonth = month === 0 ? 11 : month - 1;
+
+ var newMonthDayCount = getDayCountOfMonth(newYear, newMonth);
+ if (newMonthDayCount < date) {
+ src.setDate(newMonthDayCount);
+ }
+
+ src.setMonth(newMonth);
+ src.setFullYear(newYear);
+
+ return new Date(src.getTime());
+ };
+
+ var nextMonth = exports.nextMonth = function nextMonth(src) {
+ var year = src.getFullYear();
+ var month = src.getMonth();
+ var date = src.getDate();
+
+ var newYear = month === 11 ? year + 1 : year;
+ var newMonth = month === 11 ? 0 : month + 1;
+
+ var newMonthDayCount = getDayCountOfMonth(newYear, newMonth);
+ if (newMonthDayCount < date) {
+ src.setDate(newMonthDayCount);
+ }
+
+ src.setMonth(newMonth);
+ src.setFullYear(newYear);
+
+ return new Date(src.getTime());
+ };
+
+ var getRangeHours = exports.getRangeHours = function getRangeHours(ranges) {
+ var hours = [];
+ var disabledHours = [];
+
+ (ranges || []).forEach(function (range) {
+ var value = range.map(function (date) {
+ return date.getHours();
+ });
+
+ disabledHours = disabledHours.concat(newArray(value[0], value[1]));
+ });
+
+ if (disabledHours.length) {
+ for (var i = 0; i < 24; i++) {
+ hours[i] = disabledHours.indexOf(i) === -1;
+ }
+ } else {
+ for (var _i = 0; _i < 24; _i++) {
+ hours[_i] = false;
+ }
+ }
+
+ return hours;
+ };
+
+ var limitRange = exports.limitRange = function limitRange(date, ranges) {
+ var format = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'yyyy-MM-dd HH:mm:ss';
+
+ if (!ranges || !ranges.length) return date;
+
+ var len = ranges.length;
+
+ date = _date2.default.parse(_date2.default.format(date, format), format);
+ for (var i = 0; i < len; i++) {
+ var range = ranges[i];
+ if (date >= range[0] && date <= range[1]) {
+ return date;
+ }
+ }
+
+ var maxDate = ranges[0][0];
+ var minDate = ranges[0][0];
+
+ ranges.forEach(function (range) {
+ minDate = new Date(Math.min(range[0], minDate));
+ maxDate = new Date(Math.max(range[1], maxDate));
+ });
+
+ return date < minDate ? minDate : maxDate;
+ };
+
+/***/ },
+/* 154 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(55);
+
+/***/ },
+/* 155 */
+/***/ function(module, exports) {
+
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('el-input', {
+ 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,
+ "disabled": _vm.disabled,
+ "size": _vm.size,
+ "placeholder": _vm.placeholder,
+ "value": _vm.displayValue,
+ "validateEvent": false
},
- maxVisibleTime: function maxVisibleTime() {
- return this.maxDate || this.minDate ? (0, _util.formatDate)(this.maxDate || this.minDate, 'HH:mm:ss') : '';
+ on: {
+ "focus": _vm.handleFocus,
+ "blur": _vm.handleBlur
},
- rightDate: function rightDate() {
- var newDate = new Date(this.date);
- var month = newDate.getMonth();
- newDate.setDate(1);
-
- if (month === 11) {
- newDate.setFullYear(newDate.getFullYear() + 1);
- newDate.setMonth(0);
- } else {
- newDate.setMonth(month + 1);
+ nativeOn: {
+ "keydown": function($event) {
+ _vm.handleKeydown($event)
+ },
+ "change": function($event) {
+ _vm.displayValue = $event.target.value
}
- return newDate;
}
- },
+ }, [(_vm.haveTrigger) ? _c('i', {
+ staticClass: "el-input__icon",
+ class: [_vm.showClose ? 'el-icon-close' : _vm.triggerClass],
+ on: {
+ "click": _vm.handleClickIcon,
+ "mouseenter": _vm.handleMouseEnterIcon,
+ "mouseleave": function($event) {
+ _vm.showClose = false
+ }
+ },
+ slot: "icon"
+ }) : _vm._e()])
+ },staticRenderFns: []}
- data: function data() {
- return {
- popperClass: '',
- minPickerWidth: 0,
- maxPickerWidth: 0,
- date: new Date(),
- minDate: '',
- maxDate: '',
- rangeState: {
- endDate: null,
- selecting: false,
- row: null,
- column: null
- },
- showTime: false,
- shortcuts: '',
- value: '',
- visible: '',
- disabledDate: '',
- firstDayOfWeek: 7,
- minTimePickerVisible: false,
- maxTimePickerVisible: false,
- width: 0
- };
- },
+/***/ },
+/* 156 */
+/***/ function(module, exports, __webpack_require__) {
+
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(157),
+ /* template */
+ __webpack_require__(173),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
+ module.exports = Component.exports
+
+
+/***/ },
+/* 157 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _util = __webpack_require__(153);
+
+ var _locale = __webpack_require__(10);
+
+ var _locale2 = _interopRequireDefault(_locale);
+
+ var _input = __webpack_require__(20);
+
+ var _input2 = _interopRequireDefault(_input);
+
+ var _time = __webpack_require__(158);
+
+ var _time2 = _interopRequireDefault(_time);
+
+ var _yearTable = __webpack_require__(164);
+
+ var _yearTable2 = _interopRequireDefault(_yearTable);
+
+ var _monthTable = __webpack_require__(167);
+
+ var _monthTable2 = _interopRequireDefault(_monthTable);
+
+ var _dateTable = __webpack_require__(170);
+
+ var _dateTable2 = _interopRequireDefault(_dateTable);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ exports.default = {
+ mixins: [_locale2.default],
watch: {
showTime: function showTime(val) {
var _this = this;
+ /* istanbul ignore if */
if (!val) return;
this.$nextTick(function (_) {
- var minInputElm = _this.$refs.minInput.$el;
- var maxInputElm = _this.$refs.maxInput.$el;
- if (minInputElm) {
- _this.minPickerWidth = minInputElm.getBoundingClientRect().width + 10;
- }
- if (maxInputElm) {
- _this.maxPickerWidth = maxInputElm.getBoundingClientRect().width + 10;
+ var inputElm = _this.$refs.input.$el;
+ if (inputElm) {
+ _this.pickerWidth = inputElm.getBoundingClientRect().width + 10;
}
});
},
- minDate: function minDate() {
- var _this2 = this;
-
- this.$nextTick(function () {
- if (_this2.maxDate && _this2.maxDate < _this2.minDate) {
- var format = 'HH:mm:ss';
-
- _this2.$refs.maxTimePicker.selectableRange = [[(0, _util.parseDate)((0, _util.formatDate)(_this2.minDate, format), format), (0, _util.parseDate)('23:59:59', format)]];
+ value: function value(newVal) {
+ if (!newVal) return;
+ newVal = new Date(newVal);
+ if (!isNaN(newVal)) {
+ if (typeof this.disabledDate === 'function' && this.disabledDate(new Date(newVal))) {
+ return;
}
- });
- },
- minTimePickerVisible: function minTimePickerVisible(val) {
- var _this3 = this;
-
- if (val) this.$nextTick(function () {
- return _this3.$refs.minTimePicker.ajustScrollTop();
- });
+ this.date = newVal;
+ this.year = newVal.getFullYear();
+ this.month = newVal.getMonth();
+ this.$emit('pick', newVal, false);
+ }
},
- maxTimePickerVisible: function maxTimePickerVisible(val) {
- var _this4 = this;
+ timePickerVisible: function timePickerVisible(val) {
+ var _this2 = this;
if (val) this.$nextTick(function () {
- return _this4.$refs.maxTimePicker.ajustScrollTop();
+ return _this2.$refs.timepicker.ajustScrollTop();
});
},
- value: function value(newVal) {
- if (!newVal) {
- this.minDate = null;
- this.maxDate = null;
- } else if (Array.isArray(newVal)) {
- this.minDate = newVal[0] ? (0, _util.toDate)(newVal[0]) : null;
- this.maxDate = newVal[1] ? (0, _util.toDate)(newVal[1]) : null;
- if (this.minDate) this.date = new Date(this.minDate);
- this.handleConfirm(true);
+ selectionMode: function selectionMode(newVal) {
+ if (newVal === 'month') {
+ /* istanbul ignore next */
+ if (this.currentView !== 'year' || this.currentView !== 'month') {
+ this.currentView = 'month';
+ }
+ } else if (newVal === 'week') {
+ this.week = (0, _util.getWeekNumber)(this.date);
}
+ },
+ date: function date(newVal) {
+ this.year = newVal.getFullYear();
+ this.month = newVal.getMonth();
+ if (this.selectionMode === 'week') this.week = (0, _util.getWeekNumber)(newVal);
}
},
methods: {
handleClear: function handleClear() {
- this.minDate = null;
- this.maxDate = null;
- this.handleConfirm(false);
+ this.date = this.$options.defaultValue ? new Date(this.$options.defaultValue) : new Date();
+ this.$emit('pick');
},
- handleDateInput: function handleDateInput(event, type) {
- var value = event.target.value;
- var parsedValue = (0, _util.parseDate)(value, 'yyyy-MM-dd');
-
- if (parsedValue) {
- if (typeof this.disabledDate === 'function' && this.disabledDate(new Date(parsedValue))) {
- return;
- }
- var target = new Date(type === 'min' ? this.minDate : this.maxDate);
- if (target) {
- target.setFullYear(parsedValue.getFullYear());
- target.setMonth(parsedValue.getMonth(), parsedValue.getDate());
- }
- }
+ resetDate: function resetDate() {
+ this.date = new Date(this.date);
},
- handleChangeRange: function handleChangeRange(val) {
- this.minDate = val.minDate;
- this.maxDate = val.maxDate;
- this.rangeState = val.rangeState;
+ showMonthPicker: function showMonthPicker() {
+ this.currentView = 'month';
},
- handleDateChange: function handleDateChange(event, type) {
- var value = event.target.value;
- var parsedValue = (0, _util.parseDate)(value, 'yyyy-MM-dd');
- if (parsedValue) {
- var target = new Date(type === 'min' ? this.minDate : this.maxDate);
- if (target) {
- target.setFullYear(parsedValue.getFullYear());
- target.setMonth(parsedValue.getMonth(), parsedValue.getDate());
- }
- if (type === 'min') {
- if (target < this.maxDate) {
- this.minDate = new Date(target.getTime());
- }
- } else {
- if (target > this.minDate) {
- this.maxDate = new Date(target.getTime());
- if (this.minDate && this.minDate > this.maxDate) {
- this.minDate = null;
- }
- }
- }
+ 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.month--;
+ if (this.month < 0) {
+ this.month = 11;
+ this.year--;
}
},
- handleTimeChange: function handleTimeChange(event, type) {
- var value = event.target.value;
- var parsedValue = (0, _util.parseDate)(value, 'HH:mm:ss');
- if (parsedValue) {
- var target = new Date(type === 'min' ? this.minDate : this.maxDate);
- if (target) {
- target.setHours(parsedValue.getHours());
- target.setMinutes(parsedValue.getMinutes());
- target.setSeconds(parsedValue.getSeconds());
- }
- if (type === 'min') {
- if (target < this.maxDate) {
- this.minDate = new Date(target.getTime());
- }
- } else {
- if (target > this.minDate) {
- this.maxDate = new Date(target.getTime());
- }
- }
- this.$refs[type + 'TimePicker'].value = target;
- this[type + 'TimePickerVisible'] = false;
+ nextMonth: function nextMonth() {
+ this.month++;
+ if (this.month > 11) {
+ this.month = 0;
+ this.year++;
}
},
- handleRangePick: function handleRangePick(val) {
- var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
-
- if (this.maxDate === val.maxDate && this.minDate === val.minDate) {
- return;
+ nextYear: function nextYear() {
+ if (this.currentView === 'year') {
+ this.$refs.yearTable.nextTenYear();
+ } else {
+ this.year++;
+ this.date.setFullYear(this.year);
+ this.resetDate();
}
- this.onPick && this.onPick(val);
- this.maxDate = val.maxDate;
- this.minDate = val.minDate;
- if (!close || this.showTime) return;
- this.handleConfirm();
},
- changeToToday: function changeToToday() {
- this.date = new Date();
+ prevYear: function prevYear() {
+ if (this.currentView === 'year') {
+ this.$refs.yearTable.prevTenYear();
+ } else {
+ this.year--;
+ this.date.setFullYear(this.year);
+ this.resetDate();
+ }
},
handleShortcutClick: function handleShortcutClick(shortcut) {
if (shortcut.onClick) {
shortcut.onClick(this);
}
},
- resetView: function resetView() {
- this.minTimePickerVisible = false;
- this.maxTimePickerVisible = false;
- },
- setTime: function setTime(date, value) {
- var oldDate = new Date(date.getTime());
- var hour = value.getHours();
- var minute = value.getMinutes();
- var second = value.getSeconds();
- oldDate.setHours(hour);
- oldDate.setMinutes(minute);
- oldDate.setSeconds(second);
- return new Date(oldDate.getTime());
- },
- handleMinTimePick: function handleMinTimePick(value, visible, first) {
- this.minDate = this.minDate || new Date();
- if (value) {
- this.minDate = this.setTime(this.minDate, value);
+ handleTimePick: function handleTimePick(picker, visible, first) {
+ if (picker) {
+ var oldDate = new Date(this.date.getTime());
+ var hour = picker.getHours();
+ var minute = picker.getMinutes();
+ var second = picker.getSeconds();
+ oldDate.setHours(hour);
+ oldDate.setMinutes(minute);
+ oldDate.setSeconds(second);
+ this.date = new Date(oldDate.getTime());
}
if (!first) {
- this.minTimePickerVisible = visible;
+ this.timePickerVisible = visible;
}
},
- handleMaxTimePick: function handleMaxTimePick(value, visible, first) {
- if (!this.maxDate) {
- var now = new Date();
- if (now >= this.minDate) {
- this.maxDate = new Date();
+ handleMonthPick: function handleMonthPick(month) {
+ this.month = month;
+ var selectionMode = this.selectionMode;
+ if (selectionMode !== 'month') {
+ this.date.setMonth(month);
+ this.currentView = 'date';
+ this.resetDate();
+ } else {
+ this.date.setMonth(month);
+ this.year && this.date.setFullYear(this.year);
+ this.resetDate();
+ var value = new Date(this.date.getFullYear(), month, 1);
+ this.$emit('pick', value);
+ }
+ },
+ handleDatePick: function handleDatePick(value) {
+ if (this.selectionMode === 'day') {
+ if (!this.showTime) {
+ this.$emit('pick', new Date(value.getTime()));
}
+ this.date.setFullYear(value.getFullYear());
+ this.date.setMonth(value.getMonth(), value.getDate());
+ } else if (this.selectionMode === 'week') {
+ this.week = value.week;
+ this.$emit('pick', value.date);
}
- if (this.maxDate && value) {
- this.maxDate = this.setTime(this.maxDate, value);
- }
+ this.resetDate();
+ },
+ handleYearPick: function handleYearPick(year) {
+ var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
- if (!first) {
- this.maxTimePickerVisible = visible;
+ this.year = year;
+ if (!close) return;
+
+ this.date.setFullYear(year);
+ if (this.selectionMode === 'year') {
+ this.$emit('pick', new Date(year, 0, 1));
+ } else {
+ this.currentView = 'month';
}
- },
- prevMonth: function prevMonth() {
- this.date = (0, _util.prevMonth)(this.date);
- },
- nextMonth: function nextMonth() {
- this.date = (0, _util.nextMonth)(this.date);
- },
- nextYear: function nextYear() {
- var date = this.date;
- date.setFullYear(date.getFullYear() + 1);
+
this.resetDate();
},
- prevYear: function prevYear() {
- var date = this.date;
- date.setFullYear(date.getFullYear() - 1);
+ changeToNow: function changeToNow() {
+ this.date.setTime(+new Date());
+ this.$emit('pick', new Date(this.date.getTime()));
this.resetDate();
},
- handleConfirm: function handleConfirm() {
- var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
-
- this.$emit('pick', [this.minDate, this.maxDate], visible);
+ confirm: function confirm() {
+ this.date.setMilliseconds(0);
+ this.$emit('pick', this.date);
},
- resetDate: function resetDate() {
- this.date = new Date(this.date);
+ resetView: function resetView() {
+ if (this.selectionMode === 'month') {
+ this.currentView = 'month';
+ } else if (this.selectionMode === 'year') {
+ this.currentView = 'year';
+ } else {
+ this.currentView = 'date';
+ }
+
+ if (this.selectionMode !== 'week') {
+ this.year = this.date.getFullYear();
+ this.month = this.date.getMonth();
+ }
}
},
- components: { TimePicker: _time2.default, DateTable: _dateTable2.default, ElInput: _input2.default }
+ components: {
+ TimePicker: _time2.default, YearTable: _yearTable2.default, MonthTable: _monthTable2.default, DateTable: _dateTable2.default, ElInput: _input2.default
+ },
+
+ mounted: function mounted() {
+ if (this.date && !this.year) {
+ this.year = this.date.getFullYear();
+ this.month = this.date.getMonth();
+ }
+ },
+ data: function data() {
+ return {
+ popperClass: '',
+ pickerWidth: 0,
+ date: this.$options.defaultValue ? new Date(this.$options.defaultValue) : new Date(),
+ value: '',
+ showTime: false,
+ selectionMode: 'day',
+ shortcuts: '',
+ visible: false,
+ currentView: 'date',
+ disabledDate: '',
+ firstDayOfWeek: 7,
+ year: null,
+ month: null,
+ week: null,
+ showWeekNumber: false,
+ timePickerVisible: false,
+ width: 0,
+ format: ''
+ };
+ },
+
+
+ computed: {
+ footerVisible: function footerVisible() {
+ return this.showTime;
+ },
+
+
+ visibleTime: {
+ get: function get() {
+ return (0, _util.formatDate)(this.date, this.timeFormat);
+ },
+ set: function set(val) {
+ if (val) {
+ var date = (0, _util.parseDate)(val, this.timeFormat);
+ if (date) {
+ date.setFullYear(this.date.getFullYear());
+ date.setMonth(this.date.getMonth());
+ date.setDate(this.date.getDate());
+ this.date = date;
+ this.$refs.timepicker.value = date;
+ this.timePickerVisible = false;
+ }
+ }
+ }
+ },
+
+ visibleDate: {
+ get: function get() {
+ return (0, _util.formatDate)(this.date, this.dateFormat);
+ },
+ set: function set(val) {
+ var date = (0, _util.parseDate)(val, this.dateFormat);
+ if (!date) {
+ return;
+ }
+ if (typeof this.disabledDate === 'function' && this.disabledDate(date)) {
+ return;
+ }
+ date.setHours(this.date.getHours());
+ date.setMinutes(this.date.getMinutes());
+ date.setSeconds(this.date.getSeconds());
+ this.date = date;
+ this.resetView();
+ }
+ },
+
+ yearLabel: function yearLabel() {
+ var year = this.year;
+ if (!year) return '';
+ var yearTranslation = this.t('el.datepicker.year');
+ if (this.currentView === 'year') {
+ var startYear = Math.floor(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 && this.format.indexOf('ss') === -1) {
+ return 'HH:mm';
+ } else {
+ return 'HH:mm:ss';
+ }
+ },
+ dateFormat: function dateFormat() {
+ if (this.format) {
+ return this.format.replace('HH:mm', '').replace(':ss', '').trim();
+ } else {
+ return 'yyyy-MM-dd';
+ }
+ }
+ }
}; //
//
//
@@ -48132,6 +47341,55 @@ module.exports =
//
//
//
+
+/***/ },
+/* 158 */
+/***/ function(module, exports, __webpack_require__) {
+
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(159),
+ /* template */
+ __webpack_require__(163),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
+
+ module.exports = Component.exports
+
+
+/***/ },
+/* 159 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _util = __webpack_require__(153);
+
+ var _locale = __webpack_require__(10);
+
+ var _locale2 = _interopRequireDefault(_locale);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
//
//
//
@@ -48153,309 +47411,139 @@ module.exports =
//
//
-/***/ },
-/* 176 */
-/***/ function(module, exports) {
+ exports.default = {
+ mixins: [_locale2.default],
- module.exports={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",
- class: [{
- 'has-sidebar': _vm.$slots.sidebar || _vm.shortcuts,
- 'has-time': _vm.showTime
- }, _vm.popperClass],
- style: ({
- width: _vm.width + 'px'
- })
- }, [_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) {
- return _c('button', {
- staticClass: "el-picker-panel__shortcut",
- attrs: {
- "type": "button"
- },
- on: {
- "click": function($event) {
- _vm.handleShortcutClick(shortcut)
- }
+ components: {
+ TimeSpinner: __webpack_require__(160)
+ },
+
+ props: {
+ pickerWidth: {},
+ date: {
+ default: function _default() {
+ return new Date();
}
- }, [_vm._v(_vm._s(shortcut.text))])
- })) : _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",
- "placeholder": _vm.t('el.datepicker.startDate'),
- "value": _vm.minVisibleDate
},
- nativeOn: {
- "input": function($event) {
- _vm.handleDateInput($event, 'min')
- },
- "change": function($event) {
- _vm.handleDateChange($event, 'min')
- }
- }
- })], 1), _c('span', {
- staticClass: "el-date-range-picker__time-picker-wrap"
- }, [_c('el-input', {
- staticClass: "el-date-range-picker__editor",
- attrs: {
- "size": "small",
- "placeholder": _vm.t('el.datepicker.startTime'),
- "value": _vm.minVisibleTime
+ visible: Boolean
+ },
+
+ watch: {
+ visible: function visible(val) {
+ this.currentVisible = val;
},
- on: {
- "focus": function($event) {
- _vm.minTimePickerVisible = !_vm.minTimePickerVisible
- }
+ pickerWidth: function pickerWidth(val) {
+ this.width = val;
},
- nativeOn: {
- "change": function($event) {
- _vm.handleTimeChange($event, 'min')
+ value: function value(newVal) {
+ var _this = this;
+
+ var date = void 0;
+ if (newVal instanceof Date) {
+ date = (0, _util.limitRange)(newVal, this.selectableRange);
+ } else if (!newVal) {
+ date = new Date();
}
- }
- }), _c('time-picker', {
- ref: "minTimePicker",
- attrs: {
- "picker-width": _vm.minPickerWidth,
- "date": _vm.minDate,
- "visible": _vm.minTimePickerVisible
+
+ this.handleChange({
+ hours: date.getHours(),
+ minutes: date.getMinutes(),
+ seconds: date.getSeconds()
+ });
+ this.$nextTick(function (_) {
+ return _this.ajustScrollTop();
+ });
},
- on: {
- "pick": _vm.handleMinTimePick
+ selectableRange: function selectableRange(val) {
+ this.$refs.spinner.selectableRange = val;
}
- })], 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",
- "placeholder": _vm.t('el.datepicker.endDate'),
- "value": _vm.maxVisibleDate,
- "readonly": !_vm.minDate
- },
- nativeOn: {
- "input": function($event) {
- _vm.handleDateInput($event, 'max')
- },
- "change": function($event) {
- _vm.handleDateChange($event, 'max')
- }
+ },
+
+ data: function data() {
+ return {
+ popperClass: '',
+ format: 'HH:mm:ss',
+ value: '',
+ hours: 0,
+ minutes: 0,
+ seconds: 0,
+ selectableRange: [],
+ currentDate: this.$options.defaultValue || this.date || new Date(),
+ currentVisible: this.visible || false,
+ width: this.pickerWidth || 0
+ };
+ },
+
+
+ computed: {
+ showSeconds: function showSeconds() {
+ return (this.format || '').indexOf('ss') !== -1;
}
- })], 1), _c('span', {
- staticClass: "el-date-range-picker__time-picker-wrap"
- }, [_c('el-input', {
- ref: "maxInput",
- staticClass: "el-date-range-picker__editor",
- attrs: {
- "size": "small",
- "placeholder": _vm.t('el.datepicker.endTime'),
- "value": _vm.maxVisibleTime,
- "readonly": !_vm.minDate
+ },
+
+ methods: {
+ handleClear: function handleClear() {
+ this.$emit('pick');
},
- on: {
- "focus": function($event) {
- _vm.minDate && (_vm.maxTimePickerVisible = !_vm.maxTimePickerVisible)
- }
+ handleCancel: function handleCancel() {
+ this.$emit('pick');
},
- nativeOn: {
- "change": function($event) {
- _vm.handleTimeChange($event, 'max')
+ handleChange: function handleChange(date) {
+ if (date.hours !== undefined) {
+ this.currentDate.setHours(date.hours);
+ this.hours = this.currentDate.getHours();
}
- }
- }), _c('time-picker', {
- ref: "maxTimePicker",
- attrs: {
- "picker-width": _vm.maxPickerWidth,
- "date": _vm.maxDate,
- "visible": _vm.maxTimePickerVisible
- },
- on: {
- "pick": _vm.handleMaxTimePick
- }
- })], 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.prevYear
- }
- }), _c('button', {
- staticClass: "el-picker-panel__icon-btn el-icon-arrow-left",
- attrs: {
- "type": "button"
- },
- on: {
- "click": _vm.prevMonth
- }
- }), _c('div', [_vm._v(_vm._s(_vm.leftLabel))])]), _c('date-table', {
- attrs: {
- "selection-mode": "range",
- "date": _vm.date,
- "year": _vm.leftYear,
- "month": _vm.leftMonth,
- "min-date": _vm.minDate,
- "max-date": _vm.maxDate,
- "range-state": _vm.rangeState,
- "disabled-date": _vm.disabledDate,
- "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"
- }, [_c('button', {
- staticClass: "el-picker-panel__icon-btn el-icon-d-arrow-right",
- attrs: {
- "type": "button"
- },
- on: {
- "click": _vm.nextYear
- }
- }), _c('button', {
- staticClass: "el-picker-panel__icon-btn el-icon-arrow-right",
- attrs: {
- "type": "button"
+ if (date.minutes !== undefined) {
+ this.currentDate.setMinutes(date.minutes);
+ this.minutes = this.currentDate.getMinutes();
+ }
+ if (date.seconds !== undefined) {
+ this.currentDate.setSeconds(date.seconds);
+ this.seconds = this.currentDate.getSeconds();
+ }
+
+ this.handleConfirm(true);
},
- on: {
- "click": _vm.nextMonth
- }
- }), _c('div', [_vm._v(_vm._s(_vm.rightLabel))])]), _c('date-table', {
- attrs: {
- "selection-mode": "range",
- "date": _vm.rightDate,
- "year": _vm.rightYear,
- "month": _vm.rightMonth,
- "min-date": _vm.minDate,
- "max-date": _vm.maxDate,
- "range-state": _vm.rangeState,
- "disabled-date": _vm.disabledDate,
- "first-day-of-week": _vm.firstDayOfWeek
+ setSelectionRange: function setSelectionRange(start, end) {
+ this.$emit('select-range', start, end);
},
- on: {
- "changerange": _vm.handleChangeRange,
- "pick": _vm.handleRangePick
- }
- })], 1)])], 2), (_vm.showTime) ? _c('div', {
- staticClass: "el-picker-panel__footer"
- }, [_c('a', {
- staticClass: "el-picker-panel__link-btn",
- on: {
- "click": _vm.handleClear
- }
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.clear')))]), _c('button', {
- staticClass: "el-picker-panel__btn",
- attrs: {
- "type": "button",
- "disabled": _vm.btnDisabled
+ handleConfirm: function handleConfirm() {
+ var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
+ var first = arguments[1];
+
+ if (first) return;
+ var date = new Date((0, _util.limitRange)(this.currentDate, this.selectableRange, 'HH:mm:ss'));
+ this.$emit('pick', date, visible, first);
},
- on: {
- "click": function($event) {
- _vm.handleConfirm()
- }
+ ajustScrollTop: function ajustScrollTop() {
+ return this.$refs.spinner.ajustScrollTop();
}
- }, [_vm._v(_vm._s(_vm.t('el.datepicker.confirm')))])]) : _vm._e()])])
- },staticRenderFns: []}
-
-/***/ },
-/* 177 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _timeSelect = __webpack_require__(178);
-
- var _timeSelect2 = _interopRequireDefault(_timeSelect);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _timeSelect2.default.install = function (Vue) {
- Vue.component(_timeSelect2.default.name, _timeSelect2.default);
- };
-
- exports.default = _timeSelect2.default;
-
-/***/ },
-/* 178 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _picker = __webpack_require__(151);
-
- var _picker2 = _interopRequireDefault(_picker);
-
- var _timeSelect = __webpack_require__(179);
-
- var _timeSelect2 = _interopRequireDefault(_timeSelect);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = {
- mixins: [_picker2.default],
+ },
- name: 'ElTimeSelect',
+ created: function created() {
+ this.hours = this.currentDate.getHours();
+ this.minutes = this.currentDate.getMinutes();
+ this.seconds = this.currentDate.getSeconds();
+ },
+ mounted: function mounted() {
+ var _this2 = this;
- beforeCreate: function beforeCreate() {
- this.type = 'time-select';
- this.panel = _timeSelect2.default;
+ this.$nextTick(function () {
+ return _this2.handleConfirm(true, true);
+ });
+ this.$emit('mounted');
}
};
/***/ },
-/* 179 */
+/* 160 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(180),
+ __webpack_require__(161),
/* template */
- __webpack_require__(181),
+ __webpack_require__(162),
/* styles */
null,
/* scopeId */
@@ -48468,354 +47556,160 @@ module.exports =
/***/ },
-/* 180 */
+/* 161 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
+ var _util = __webpack_require__(153);
+
var _scrollbar = __webpack_require__(25);
var _scrollbar2 = _interopRequireDefault(_scrollbar);
- var _scrollIntoView = __webpack_require__(112);
+ var _debounce = __webpack_require__(69);
- var _scrollIntoView2 = _interopRequireDefault(_scrollIntoView);
+ var _debounce2 = _interopRequireDefault(_debounce);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
-
- 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
- };
+ exports.default = {
+ components: { ElScrollbar: _scrollbar2.default },
- next.minutes += stepValue.minutes;
- next.hours += stepValue.hours;
+ props: {
+ hours: {
+ type: Number,
+ default: 0
+ },
- next.hours += Math.floor(next.minutes / 60);
- next.minutes = next.minutes % 60;
+ minutes: {
+ type: Number,
+ default: 0
+ },
- return formatTime(next);
- };
+ seconds: {
+ type: Number,
+ default: 0
+ },
- exports.default = {
- components: { ElScrollbar: _scrollbar2.default },
+ showSeconds: {
+ type: Boolean,
+ default: true
+ }
+ },
watch: {
- value: function value(val) {
- var _this = this;
-
- if (!val) return;
- if (this.minTime && compareTime(val, this.minTime) < 0) {
- this.$emit('pick');
- } else if (this.maxTime && compareTime(val, this.maxTime) > 0) {
- this.$emit('pick');
+ hoursPrivate: function hoursPrivate(newVal, oldVal) {
+ if (!(newVal >= 0 && newVal <= 23)) {
+ this.hoursPrivate = oldVal;
}
- this.$nextTick(function () {
- return _this.scrollToOption();
- });
+ this.ajustElTop('hour', newVal);
+ this.$emit('change', { hours: newVal });
+ },
+ minutesPrivate: function minutesPrivate(newVal, oldVal) {
+ if (!(newVal >= 0 && newVal <= 59)) {
+ this.minutesPrivate = oldVal;
+ }
+ this.ajustElTop('minute', newVal);
+ this.$emit('change', { minutes: newVal });
+ },
+ secondsPrivate: function secondsPrivate(newVal, oldVal) {
+ if (!(newVal >= 0 && newVal <= 59)) {
+ this.secondsPrivate = oldVal;
+ }
+ this.ajustElTop('second', newVal);
+ this.$emit('change', { seconds: newVal });
}
},
- methods: {
- handleClick: function handleClick(item) {
- if (!item.disabled) {
- this.$emit('pick', item.value);
- }
+ computed: {
+ hoursList: function hoursList() {
+ return (0, _util.getRangeHours)(this.selectableRange);
},
- handleClear: function handleClear() {
- this.$emit('pick');
+ hourEl: function hourEl() {
+ return this.$refs.hour.wrap;
},
- scrollToOption: function scrollToOption() {
- var className = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'selected';
-
- var menu = this.$refs.popper.querySelector('.el-picker-panel__content');
- (0, _scrollIntoView2.default)(menu, menu.getElementsByClassName(className)[0]);
+ minuteEl: function minuteEl() {
+ return this.$refs.minute.wrap;
},
- handleMenuEnter: function handleMenuEnter() {
- var _this2 = this;
-
- this.$nextTick(function () {
- return _this2.scrollToOption();
- });
+ secondEl: function secondEl() {
+ return this.$refs.second.wrap;
}
},
data: function data() {
return {
- popperClass: '',
- start: '09:00',
- end: '18:00',
- step: '00:30',
- value: '',
- visible: false,
- minTime: '',
- maxTime: '',
- width: 0
+ hoursPrivate: 0,
+ minutesPrivate: 0,
+ secondsPrivate: 0,
+ selectableRange: []
};
},
+ created: function created() {
+ var _this = this;
+ this.debounceAjustElTop = (0, _debounce2.default)(100, function (type) {
+ return _this.ajustElTop(type, _this[type + 's']);
+ });
+ },
+ mounted: function mounted() {
+ var _this2 = this;
- computed: {
- items: function items() {
- var start = this.start;
- var end = this.end;
- var step = this.step;
+ this.$nextTick(function () {
+ _this2.bindScrollEvent();
+ });
+ },
- 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);
- }
+ methods: {
+ handleClick: function handleClick(type, value, disabled) {
+ if (value.disabled) {
+ return;
}
- return result;
- }
- }
- };
-
-/***/ },
-/* 181 */
-/***/ function(module, exports) {
+ this[type + 'Private'] = value.value >= 0 ? value.value : value;
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('transition', {
- attrs: {
- "name": "el-zoom-in-top"
+ this.emitSelectRange(type);
},
- 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",
- 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', {
- staticClass: "time-select-item",
- class: {
- selected: _vm.value === item.value, disabled: item.disabled
- },
- attrs: {
- "disabled": item.disabled
- },
- on: {
- "click": function($event) {
- _vm.handleClick(item)
- }
+ 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);
}
- }, [_vm._v(_vm._s(item.value))])
- }))], 1)])
- },staticRenderFns: []}
-
-/***/ },
-/* 182 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
+ },
+ bindScrollEvent: function bindScrollEvent() {
+ var _this3 = this;
- var _timePicker = __webpack_require__(183);
-
- var _timePicker2 = _interopRequireDefault(_timePicker);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _timePicker2.default.install = function (Vue) {
- Vue.component(_timePicker2.default.name, _timePicker2.default);
- };
-
- exports.default = _timePicker2.default;
-
-/***/ },
-/* 183 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _picker = __webpack_require__(151);
-
- var _picker2 = _interopRequireDefault(_picker);
-
- var _time = __webpack_require__(158);
-
- var _time2 = _interopRequireDefault(_time);
-
- var _timeRange = __webpack_require__(184);
-
- var _timeRange2 = _interopRequireDefault(_timeRange);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = {
- mixins: [_picker2.default],
-
- name: 'ElTimePicker',
-
- props: {
- isRange: Boolean
- },
-
- data: function data() {
- return {
- type: ''
- };
- },
-
-
- watch: {
- isRange: function isRange(_isRange) {
- if (this.picker) {
- this.unmountPicker();
- this.type = _isRange ? 'timerange' : 'time';
- this.panel = _isRange ? _timeRange2.default : _time2.default;
- this.mountPicker();
- } else {
- this.type = _isRange ? 'timerange' : 'time';
- this.panel = _isRange ? _timeRange2.default : _time2.default;
- }
+ var bindFuntion = function bindFuntion(type) {
+ _this3[type + 'El'].onscroll = function (e) {
+ return _this3.handleScroll(type, e);
+ };
+ };
+ bindFuntion('hour');
+ bindFuntion('minute');
+ bindFuntion('second');
+ },
+ handleScroll: function handleScroll(type) {
+ var ajust = {};
+ ajust[type + 's'] = Math.min(Math.floor((this[type + 'El'].scrollTop - 80) / 32 + 3), '' + type === 'hour' ? 23 : 59);
+ this.debounceAjustElTop(type);
+ this.$emit('change', ajust);
+ },
+ ajustScrollTop: function ajustScrollTop() {
+ this.ajustElTop('hour', this.hours);
+ this.ajustElTop('minute', this.minutes);
+ this.ajustElTop('second', this.seconds);
+ },
+ ajustElTop: function ajustElTop(type, value) {
+ this[type + 'El'].scrollTop = Math.max(0, (value - 2.5) * 32 + 80);
}
- },
-
- created: function created() {
- this.type = this.isRange ? 'timerange' : 'time';
- this.panel = this.isRange ? _timeRange2.default : _time2.default;
}
- };
-
-/***/ },
-/* 184 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(185),
- /* template */
- __webpack_require__(186),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
-
-/***/ },
-/* 185 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _util = __webpack_require__(153);
-
- var _locale = __webpack_require__(10);
-
- var _locale2 = _interopRequireDefault(_locale);
-
- var _timeSpinner = __webpack_require__(160);
-
- var _timeSpinner2 = _interopRequireDefault(_timeSpinner);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- var MIN_TIME = (0, _util.parseDate)('00:00:00', 'HH:mm:ss'); //
- //
- //
- //
- //
- //
- //
- //
+ }; //
//
//
//
@@ -48868,170 +47762,120 @@ module.exports =
//
//
- var MAX_TIME = (0, _util.parseDate)('23:59:59', 'HH:mm:ss');
- var isDisabled = function isDisabled(minTime, maxTime) {
- var minValue = minTime.getHours() * 3600 + minTime.getMinutes() * 60 + minTime.getSeconds();
- var maxValue = maxTime.getHours() * 3600 + maxTime.getMinutes() * 60 + maxTime.getSeconds();
-
- return minValue > maxValue;
- };
- var clacTime = function clacTime(time) {
- time = Array.isArray(time) ? time : [time];
- var minTime = time[0] || new Date();
- var date = new Date();
- date.setHours(date.getHours() + 1);
- var maxTime = time[1] || date;
-
- if (minTime > maxTime) return clacTime();
- return { minTime: minTime, maxTime: maxTime };
- };
-
- exports.default = {
- mixins: [_locale2.default],
-
- components: { TimeSpinner: _timeSpinner2.default },
-
- computed: {
- showSeconds: function showSeconds() {
- return (this.format || '').indexOf('ss') !== -1;
- }
- },
-
- props: ['value'],
-
- data: function data() {
- var time = clacTime(this.$options.defaultValue);
-
- return {
- popperClass: '',
- minTime: time.minTime,
- maxTime: time.maxTime,
- btnDisabled: isDisabled(time.minTime, time.maxTime),
- maxHours: time.maxTime.getHours(),
- maxMinutes: time.maxTime.getMinutes(),
- maxSeconds: time.maxTime.getSeconds(),
- minHours: time.minTime.getHours(),
- minMinutes: time.minTime.getMinutes(),
- minSeconds: time.minTime.getSeconds(),
- format: 'HH:mm:ss',
- visible: false,
- width: 0
- };
- },
-
-
- watch: {
- value: function value(newVal) {
- var _this = this;
+/***/ },
+/* 162 */
+/***/ function(module, exports) {
- this.panelCreated();
- this.$nextTick(function (_) {
- return _this.ajustScrollTop();
- });
+ module.exports={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
}
- },
-
- methods: {
- panelCreated: function panelCreated() {
- var time = clacTime(this.value);
- if (time.minTime === this.minTime && time.maxTime === this.maxTime) {
- return;
- }
-
- this.handleMinChange({
- hours: time.minTime.getHours(),
- minutes: time.minTime.getMinutes(),
- seconds: time.minTime.getSeconds()
- });
- this.handleMaxChange({
- hours: time.maxTime.getHours(),
- minutes: time.maxTime.getMinutes(),
- seconds: time.maxTime.getSeconds()
- });
- },
- handleClear: function handleClear() {
- this.handleCancel();
- },
- handleCancel: function handleCancel() {
- this.$emit('pick');
- },
- handleChange: function handleChange() {
- if (this.minTime > this.maxTime) return;
- MIN_TIME.setFullYear(this.minTime.getFullYear());
- MIN_TIME.setMonth(this.minTime.getMonth(), this.minTime.getDate());
- MAX_TIME.setFullYear(this.maxTime.getFullYear());
- MAX_TIME.setMonth(this.maxTime.getMonth(), this.maxTime.getDate());
- this.$refs.minSpinner.selectableRange = [[MIN_TIME, this.maxTime]];
- this.$refs.maxSpinner.selectableRange = [[this.minTime, MAX_TIME]];
- this.handleConfirm(true);
+ }, [_c('el-scrollbar', {
+ ref: "hour",
+ staticClass: "el-time-spinner__wrapper",
+ attrs: {
+ "wrap-style": "max-height: inherit;",
+ "view-class": "el-time-spinner__list",
+ "noresize": "",
+ "tag": "ul"
},
- handleMaxChange: function handleMaxChange(date) {
- if (date.hours !== undefined) {
- this.maxTime.setHours(date.hours);
- this.maxHours = this.maxTime.getHours();
- }
- if (date.minutes !== undefined) {
- this.maxTime.setMinutes(date.minutes);
- this.maxMinutes = this.maxTime.getMinutes();
+ nativeOn: {
+ "mouseenter": function($event) {
+ _vm.emitSelectRange('hours')
}
- if (date.seconds !== undefined) {
- this.maxTime.setSeconds(date.seconds);
- this.maxSeconds = this.maxTime.getSeconds();
+ }
+ }, _vm._l((_vm.hoursList), function(disabled, hour) {
+ return _c('li', {
+ staticClass: "el-time-spinner__item",
+ class: {
+ 'active': hour === _vm.hours, 'disabled': disabled
+ },
+ attrs: {
+ "track-by": "hour"
+ },
+ domProps: {
+ "textContent": _vm._s(hour)
+ },
+ on: {
+ "click": function($event) {
+ _vm.handleClick('hours', {
+ value: hour,
+ disabled: disabled
+ }, true)
+ }
}
- this.handleChange();
+ })
+ })), _c('el-scrollbar', {
+ ref: "minute",
+ staticClass: "el-time-spinner__wrapper",
+ attrs: {
+ "wrap-style": "max-height: inherit;",
+ "view-class": "el-time-spinner__list",
+ "noresize": "",
+ "tag": "ul"
},
- handleMinChange: function handleMinChange(date) {
- if (date.hours !== undefined) {
- this.minTime.setHours(date.hours);
- this.minHours = this.minTime.getHours();
- }
- if (date.minutes !== undefined) {
- this.minTime.setMinutes(date.minutes);
- this.minMinutes = this.minTime.getMinutes();
+ nativeOn: {
+ "mouseenter": function($event) {
+ _vm.emitSelectRange('minutes')
}
- if (date.seconds !== undefined) {
- this.minTime.setSeconds(date.seconds);
- this.minSeconds = this.minTime.getSeconds();
+ }
+ }, _vm._l((60), function(minute, key) {
+ return _c('li', {
+ staticClass: "el-time-spinner__item",
+ class: {
+ 'active': key === _vm.minutes
+ },
+ domProps: {
+ "textContent": _vm._s(key)
+ },
+ on: {
+ "click": function($event) {
+ _vm.handleClick('minutes', key, true)
+ }
}
-
- this.handleChange();
- },
- setMinSelectionRange: function setMinSelectionRange(start, end) {
- this.$emit('select-range', start, end);
- },
- setMaxSelectionRange: function setMaxSelectionRange(start, end) {
- this.$emit('select-range', start + 11, end + 11);
- },
- handleConfirm: function handleConfirm() {
- var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- var first = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
-
- var minSelectableRange = this.$refs.minSpinner.selectableRange;
- var maxSelectableRange = this.$refs.maxSpinner.selectableRange;
-
- this.minTime = (0, _util.limitRange)(this.minTime, minSelectableRange);
- this.maxTime = (0, _util.limitRange)(this.maxTime, maxSelectableRange);
-
- if (first) return;
- this.$emit('pick', [this.minTime, this.maxTime], visible, first);
+ })
+ })), _c('el-scrollbar', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.showSeconds),
+ expression: "showSeconds"
+ }],
+ ref: "second",
+ staticClass: "el-time-spinner__wrapper",
+ attrs: {
+ "wrap-style": "max-height: inherit;",
+ "view-class": "el-time-spinner__list",
+ "noresize": "",
+ "tag": "ul"
},
- ajustScrollTop: function ajustScrollTop() {
- this.$refs.minSpinner.ajustScrollTop();
- this.$refs.maxSpinner.ajustScrollTop();
+ nativeOn: {
+ "mouseenter": function($event) {
+ _vm.emitSelectRange('seconds')
+ }
}
- },
-
- mounted: function mounted() {
- var _this2 = this;
-
- this.$nextTick(function () {
- return _this2.handleConfirm(true, true);
- });
- }
- };
+ }, _vm._l((60), function(second, key) {
+ return _c('li', {
+ staticClass: "el-time-spinner__item",
+ class: {
+ 'active': key === _vm.seconds
+ },
+ domProps: {
+ "textContent": _vm._s(key)
+ },
+ on: {
+ "click": function($event) {
+ _vm.handleClick('seconds', key, true)
+ }
+ }
+ })
+ }))], 1)
+ },staticRenderFns: []}
/***/ },
-/* 186 */
+/* 163 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
@@ -49040,7 +47884,6 @@ module.exports =
"name": "el-zoom-in-top"
},
on: {
- "before-enter": _vm.panelCreated,
"after-leave": function($event) {
_vm.$emit('dodestroy')
}
@@ -49049,59 +47892,32 @@ module.exports =
directives: [{
name: "show",
rawName: "v-show",
- value: (_vm.visible),
- expression: "visible"
+ value: (_vm.currentVisible),
+ expression: "currentVisible"
}],
- staticClass: "el-time-range-picker el-picker-panel",
+ staticClass: "el-time-panel",
class: _vm.popperClass,
style: ({
width: _vm.width + 'px'
})
}, [_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
- }
- }, [_c('time-spinner', {
- ref: "minSpinner",
- attrs: {
- "show-seconds": _vm.showSeconds,
- "hours": _vm.minHours,
- "minutes": _vm.minMinutes,
- "seconds": _vm.minSeconds
- },
- 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",
+ staticClass: "el-time-panel__content",
class: {
'has-seconds': _vm.showSeconds
}
}, [_c('time-spinner', {
- ref: "maxSpinner",
+ ref: "spinner",
attrs: {
"show-seconds": _vm.showSeconds,
- "hours": _vm.maxHours,
- "minutes": _vm.maxMinutes,
- "seconds": _vm.maxSeconds
+ "hours": _vm.hours,
+ "minutes": _vm.minutes,
+ "seconds": _vm.seconds
},
on: {
- "change": _vm.handleMaxChange,
- "select-range": _vm.setMaxSelectionRange
+ "change": _vm.handleChange,
+ "select-range": _vm.setSelectionRange
}
- })], 1)])]), _c('div', {
+ })], 1), _c('div', {
staticClass: "el-time-panel__footer"
}, [_c('button', {
staticClass: "el-time-panel__btn cancel",
@@ -49109,15 +47925,12 @@ module.exports =
"type": "button"
},
on: {
- "click": function($event) {
- _vm.handleCancel()
- }
+ "click": _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
+ "type": "button"
},
on: {
"click": function($event) {
@@ -49128,47 +47941,14 @@ module.exports =
},staticRenderFns: []}
/***/ },
-/* 187 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _main = __webpack_require__(188);
-
- var _main2 = _interopRequireDefault(_main);
-
- var _directive = __webpack_require__(191);
-
- var _directive2 = _interopRequireDefault(_directive);
-
- var _vue = __webpack_require__(133);
-
- var _vue2 = _interopRequireDefault(_vue);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- _vue2.default.directive('popover', _directive2.default);
-
- /* istanbul ignore next */
- _main2.default.install = function (Vue) {
- Vue.directive('popover', _directive2.default);
- Vue.component(_main2.default.name, _main2.default);
- };
- _main2.default.directive = _directive2.default;
-
- exports.default = _main2.default;
-
-/***/ },
-/* 188 */
+/* 164 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(189),
+ __webpack_require__(165),
/* template */
- __webpack_require__(190),
+ __webpack_require__(166),
/* styles */
null,
/* scopeId */
@@ -49181,21 +47961,101 @@ module.exports =
/***/ },
-/* 189 */
+/* 165 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _vuePopper = __webpack_require__(24);
+ var _dom = __webpack_require__(44);
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
+ exports.default = {
+ props: {
+ disabledDate: {},
+ date: {},
+ year: {}
+ },
- var _dom = __webpack_require__(44);
+ computed: {
+ startYear: function startYear() {
+ return Math.floor(this.year / 10) * 10;
+ }
+ },
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ methods: {
+ getCellStyle: function getCellStyle(year) {
+ var style = {};
+ var date = new Date(0);
+ date.setFullYear(year);
+ date.setHours(0);
+ var nextYear = new Date(date);
+ nextYear.setFullYear(year + 1);
+
+ var flag = false;
+ if (typeof this.disabledDate === 'function') {
+
+ while (date < nextYear) {
+ if (this.disabledDate(date)) {
+ date = new Date(date.getTime() + 8.64e7);
+ } else {
+ break;
+ }
+ }
+ if (date - nextYear === 0) flag = true;
+ }
+
+ style.disabled = flag;
+ style.current = Number(this.year) === year;
+
+ return style;
+ },
+ nextTenYear: function nextTenYear() {
+ this.$emit('pick', Number(this.year) + 10, false);
+ },
+ prevTenYear: function prevTenYear() {
+ this.$emit('pick', Number(this.year) - 10, false);
+ },
+ handleYearTableClick: function handleYearTableClick(event) {
+ var target = event.target;
+ if (target.tagName === 'A') {
+ if ((0, _dom.hasClass)(target.parentNode, 'disabled')) return;
+ var year = target.textContent || target.innerText;
+ this.$emit('pick', Number(year));
+ }
+ }
+ }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
//
//
//
@@ -49211,655 +48071,1033 @@ module.exports =
//
//
//
- //
- //
-
- exports.default = {
- name: 'ElPopover',
- mixins: [_vuePopper2.default],
+/***/ },
+/* 166 */
+/***/ function(module, exports) {
- props: {
- trigger: {
- type: String,
- default: 'click',
- validator: function validator(value) {
- return ['click', 'focus', 'hover', 'manual'].indexOf(value) > -1;
- }
- },
- openDelay: {
- type: Number,
- default: 0
- },
- title: String,
- disabled: Boolean,
- content: String,
- reference: {},
- popperClass: String,
- width: {},
- visibleArrow: {
- default: true
- },
- transition: {
- type: String,
- default: 'fade-in-linear'
+ module.exports={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')])])])
+ },staticRenderFns: []}
- watch: {
- showPopper: function showPopper(newVal, oldVal) {
- newVal ? this.$emit('show') : this.$emit('hide');
+/***/ },
+/* 167 */
+/***/ function(module, exports, __webpack_require__) {
+
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(168),
+ /* template */
+ __webpack_require__(169),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
+
+ module.exports = Component.exports
+
+
+/***/ },
+/* 168 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _locale = __webpack_require__(10);
+
+ var _locale2 = _interopRequireDefault(_locale);
+
+ var _dom = __webpack_require__(44);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+ exports.default = {
+ props: {
+ disabledDate: {},
+ date: {},
+ month: {
+ type: Number
}
},
+ mixins: [_locale2.default],
+ methods: {
+ getCellStyle: function getCellStyle(month) {
+ var style = {};
- mounted: function mounted() {
- var reference = this.reference || this.$refs.reference;
- var popper = this.popper || this.$refs.popper;
+ var year = this.date.getFullYear();
+ var date = new Date(0);
+ date.setFullYear(year);
+ date.setMonth(month);
+ date.setHours(0);
+ var nextMonth = new Date(date);
+ nextMonth.setMonth(month + 1);
- if (!reference && this.$slots.reference && this.$slots.reference[0]) {
- reference = this.referenceElm = this.$slots.reference[0].elm;
- }
- if (this.trigger === 'click') {
- (0, _dom.on)(reference, 'click', this.doToggle);
- (0, _dom.on)(document, 'click', this.handleDocumentClick);
- } else if (this.trigger === 'hover') {
- (0, _dom.on)(reference, 'mouseenter', this.handleMouseEnter);
- (0, _dom.on)(popper, 'mouseenter', this.handleMouseEnter);
- (0, _dom.on)(reference, 'mouseleave', this.handleMouseLeave);
- (0, _dom.on)(popper, 'mouseleave', this.handleMouseLeave);
- } else if (this.trigger === 'focus') {
- var found = false;
+ var flag = false;
+ if (typeof this.disabledDate === 'function') {
- if ([].slice.call(reference.children).length) {
- var children = reference.childNodes;
- var len = children.length;
- for (var i = 0; i < len; i++) {
- if (children[i].nodeName === 'INPUT' || children[i].nodeName === 'TEXTAREA') {
- (0, _dom.on)(children[i], 'focus', this.doShow);
- (0, _dom.on)(children[i], 'blur', this.doClose);
- found = true;
+ while (date < nextMonth) {
+ if (this.disabledDate(date)) {
+ date = new Date(date.getTime() + 8.64e7);
+ flag = true;
+ } else {
+ flag = false;
break;
}
}
}
- if (found) return;
- if (reference.nodeName === 'INPUT' || reference.nodeName === 'TEXTAREA') {
- (0, _dom.on)(reference, 'focus', this.doShow);
- (0, _dom.on)(reference, 'blur', this.doClose);
- } else {
- (0, _dom.on)(reference, 'mousedown', this.doShow);
- (0, _dom.on)(reference, 'mouseup', this.doClose);
- }
- }
- },
-
-
- methods: {
- doToggle: function doToggle() {
- this.showPopper = !this.showPopper;
- },
- doShow: function doShow() {
- this.showPopper = true;
- },
- doClose: function doClose() {
- this.showPopper = false;
- },
- handleMouseEnter: function handleMouseEnter() {
- var _this = this;
- clearTimeout(this._timer);
- if (this.openDelay) {
- this._timer = setTimeout(function () {
- _this.showPopper = true;
- }, this.openDelay);
- } else {
- this.showPopper = true;
- }
- },
- handleMouseLeave: function handleMouseLeave() {
- var _this2 = this;
+ style.disabled = flag;
+ style.current = this.month === month;
- clearTimeout(this._timer);
- this._timer = setTimeout(function () {
- _this2.showPopper = false;
- }, 200);
+ return style;
},
- handleDocumentClick: function handleDocumentClick(e) {
- var reference = this.reference || this.$refs.reference;
- var popper = this.popper || this.$refs.popper;
+ handleMonthTableClick: function handleMonthTableClick(event) {
+ var target = event.target;
+ if (target.tagName !== 'A') return;
+ if ((0, _dom.hasClass)(target.parentNode, 'disabled')) return;
+ var column = target.parentNode.cellIndex;
+ var row = target.parentNode.parentNode.rowIndex;
+ var month = row * 4 + column;
- 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;
+ this.$emit('pick', month);
}
- },
-
- destroyed: function destroyed() {
- var reference = this.reference;
-
- (0, _dom.off)(reference, 'click', this.doToggle);
- (0, _dom.off)(reference, 'mouseup', this.doClose);
- (0, _dom.off)(reference, 'mousedown', this.doShow);
- (0, _dom.off)(reference, 'focus', this.doShow);
- (0, _dom.off)(reference, 'blur', this.doClose);
- (0, _dom.off)(reference, 'mouseleave', this.handleMouseLeave);
- (0, _dom.off)(reference, 'mouseenter', this.handleMouseEnter);
- (0, _dom.off)(document, 'click', this.handleDocumentClick);
}
};
/***/ },
-/* 190 */
+/* 169 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('span', [_c('transition', {
- attrs: {
- "name": _vm.transition
- },
+ return _c('table', {
+ staticClass: "el-month-table",
on: {
- "after-leave": _vm.doDestroy
- }
- }, [_c('div', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (!_vm.disabled && _vm.showPopper),
- expression: "!disabled && showPopper"
- }],
- ref: "popper",
- staticClass: "el-popover",
- class: [_vm.popperClass],
- style: ({
- width: _vm.width + 'px'
- })
- }, [(_vm.title) ? _c('div', {
- staticClass: "el-popover__title",
- domProps: {
- "textContent": _vm._s(_vm.title)
+ "click": _vm.handleMonthTableClick
}
- }) : _vm._e(), _vm._t("default", [_vm._v(_vm._s(_vm.content))])], 2)]), _vm._t("reference")], 2)
+ }, [_c('tbody', [_c('tr', [_c('td', {
+ class: _vm.getCellStyle(0)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.jan')))])]), _c('td', {
+ class: _vm.getCellStyle(1)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.feb')))])]), _c('td', {
+ class: _vm.getCellStyle(2)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.mar')))])]), _c('td', {
+ class: _vm.getCellStyle(3)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.apr')))])])]), _c('tr', [_c('td', {
+ class: _vm.getCellStyle(4)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.may')))])]), _c('td', {
+ class: _vm.getCellStyle(5)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.jun')))])]), _c('td', {
+ class: _vm.getCellStyle(6)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.jul')))])]), _c('td', {
+ class: _vm.getCellStyle(7)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.aug')))])])]), _c('tr', [_c('td', {
+ class: _vm.getCellStyle(8)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.sep')))])]), _c('td', {
+ class: _vm.getCellStyle(9)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.oct')))])]), _c('td', {
+ class: _vm.getCellStyle(10)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.nov')))])]), _c('td', {
+ class: _vm.getCellStyle(11)
+ }, [_c('a', {
+ staticClass: "cell"
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.months.dec')))])])])])])
},staticRenderFns: []}
/***/ },
-/* 191 */
-/***/ function(module, exports) {
-
- "use strict";
-
- exports.__esModule = true;
- exports.default = {
- bind: function bind(el, binding, vnode) {
- vnode.context.$refs[binding.arg].$refs.reference = el;
- }
- };
-
-/***/ },
-/* 192 */
+/* 170 */
/***/ function(module, exports, __webpack_require__) {
- 'use strict';
-
- exports.__esModule = true;
-
- var _main = __webpack_require__(193);
-
- var _main2 = _interopRequireDefault(_main);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(171),
+ /* template */
+ __webpack_require__(172),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- /* istanbul ignore next */
- _main2.default.install = function (Vue) {
- Vue.component(_main2.default.name, _main2.default);
- };
+ module.exports = Component.exports
- exports.default = _main2.default;
/***/ },
-/* 193 */
+/* 171 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _vuePopper = __webpack_require__(24);
-
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
-
- var _debounce = __webpack_require__(69);
-
- var _debounce2 = _interopRequireDefault(_debounce);
+ var _util = __webpack_require__(153);
- var _vdom = __webpack_require__(194);
+ var _dom = __webpack_require__(44);
- var _vue = __webpack_require__(133);
+ var _locale = __webpack_require__(10);
- var _vue2 = _interopRequireDefault(_vue);
+ var _locale2 = _interopRequireDefault(_locale);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- exports.default = {
- name: 'ElTooltip',
-
- mixins: [_vuePopper2.default],
-
- props: {
- openDelay: {
- type: Number,
- default: 0
- },
- disabled: Boolean,
- manual: Boolean,
- effect: {
- type: String,
- default: 'dark'
+ var _WEEKS = ['sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat']; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+ var clearHours = function clearHours(time) {
+ var cloneDate = new Date(time);
+ cloneDate.setHours(0, 0, 0, 0);
+ return cloneDate.getTime();
+ };
+
+ exports.default = {
+ mixins: [_locale2.default],
+
+ props: {
+ firstDayOfWeek: {
+ default: 7,
+ type: Number,
+ validator: function validator(val) {
+ return val >= 1 && val <= 7;
+ }
},
- popperClass: String,
- content: String,
- visibleArrow: {
- default: true
+
+ date: {},
+
+ year: {},
+
+ month: {},
+
+ week: {},
+
+ selectionMode: {
+ default: 'day'
},
- transition: {
- type: String,
- default: 'el-fade-in-linear'
+
+ showWeekNumber: {
+ type: Boolean,
+ default: false
},
- popperOptions: {
+
+ disabledDate: {},
+
+ minDate: {},
+
+ maxDate: {},
+
+ rangeState: {
default: function _default() {
return {
- boundariesPadding: 10,
- gpuAcceleration: false
+ endDate: null,
+ selecting: false,
+ row: null,
+ column: null
};
}
- },
- enterable: {
- type: Boolean,
- default: true
}
},
- beforeCreate: function beforeCreate() {
- var _this = this;
+ 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);
+ },
+ monthDate: function monthDate() {
+ return this.date.getDate();
+ },
+ startDate: function startDate() {
+ return (0, _util.getStartDateOfMonth)(this.year, this.month);
+ },
+ rows: function rows() {
+ var date = new Date(this.year, this.month, 1);
+ var day = (0, _util.getFirstDayOfMonth)(date); // day of first day
+ var dateCountOfMonth = (0, _util.getDayCountOfMonth)(date.getFullYear(), date.getMonth());
+ var dateCountOfLastMonth = (0, _util.getDayCountOfMonth)(date.getFullYear(), date.getMonth() === 0 ? 11 : date.getMonth() - 1);
- if (this.$isServer) return;
+ day = day === 0 ? 7 : day;
- this.popperVM = new _vue2.default({
- data: { node: '' },
- render: function render(h) {
- return this.node;
- }
- }).$mount();
+ var offset = this.offsetDay;
+ var rows = this.tableRows;
+ var count = 1;
+ var firstDayPosition = void 0;
- this.debounceClose = (0, _debounce2.default)(200, function () {
- return _this.handleClosePopper();
- });
- },
- render: function render(h) {
- var _this2 = this;
+ var startDate = this.startDate;
+ var disabledDate = this.disabledDate;
+ var now = clearHours(new Date());
- if (this.popperVM) {
- this.popperVM.node = h(
- 'transition',
- {
- attrs: {
- name: this.transition
- },
- on: {
- 'afterLeave': this.doDestroy
+ for (var i = 0; i < 6; i++) {
+ var row = rows[i];
+
+ if (this.showWeekNumber) {
+ if (!row[0]) {
+ row[0] = { type: 'week', text: (0, _util.getWeekNumber)(new Date(startDate.getTime() + _util.DAY_DURATION * (i * 7 + 1))) };
}
- },
- [h(
- 'div',
- {
- on: {
- 'mouseleave': function mouseleave() {
- _this2.setExpectedState(false);_this2.debounceClose();
- },
- 'mouseenter': function mouseenter() {
- _this2.setExpectedState(true);
- }
- },
+ }
- ref: 'popper',
- directives: [{
- name: 'show',
- value: !this.disabled && this.showPopper
- }],
+ for (var j = 0; j < 7; j++) {
+ var cell = row[this.showWeekNumber ? j + 1 : j];
+ if (!cell) {
+ cell = { row: i, column: j, type: 'normal', inRange: false, start: false, end: false };
+ }
- 'class': ['el-tooltip__popper', 'is-' + this.effect, this.popperClass] },
- [this.$slots.content || this.content]
- )]
- );
- }
+ cell.type = 'normal';
- if (!this.$slots.default || !this.$slots.default.length) return this.$slots.default;
+ var index = i * 7 + j;
+ var time = startDate.getTime() + _util.DAY_DURATION * (index - offset);
+ cell.inRange = time >= clearHours(this.minDate) && time <= clearHours(this.maxDate);
+ cell.start = this.minDate && time === clearHours(this.minDate);
+ cell.end = this.maxDate && time === clearHours(this.maxDate);
+ var isToday = time === now;
- var vnode = (0, _vdom.getFirstComponentChild)(this.$slots.default);
- if (!vnode) return vnode;
- var data = vnode.data = vnode.data || {};
- var on = vnode.data.on = vnode.data.on || {};
- var nativeOn = vnode.data.nativeOn = vnode.data.nativeOn || {};
+ if (isToday) {
+ cell.type = 'today';
+ }
- on.mouseenter = this.addEventHandle(on.mouseenter, function () {
- _this2.setExpectedState(true);_this2.handleShowPopper();
- });
- on.mouseleave = this.addEventHandle(on.mouseleave, function () {
- _this2.setExpectedState(false);_this2.debounceClose();
- });
- nativeOn.mouseenter = this.addEventHandle(nativeOn.mouseenter, function () {
- _this2.setExpectedState(true);_this2.handleShowPopper();
- });
- nativeOn.mouseleave = this.addEventHandle(nativeOn.mouseleave, function () {
- _this2.setExpectedState(false);_this2.debounceClose();
- });
- data.staticClass = this.concatClass(data.staticClass, 'el-tooltip');
+ if (i >= 0 && i <= 1) {
+ if (j + i * 7 >= day + offset) {
+ cell.text = count++;
+ if (count === 2) {
+ firstDayPosition = i * 7 + j;
+ }
+ } else {
+ cell.text = dateCountOfLastMonth - (day + offset - j % 7) + 1 + i * 7;
+ cell.type = 'prev-month';
+ }
+ } else {
+ if (count <= dateCountOfMonth) {
+ cell.text = count++;
+ if (count === 2) {
+ firstDayPosition = i * 7 + j;
+ }
+ } else {
+ cell.text = count++ - dateCountOfMonth;
+ cell.type = 'next-month';
+ }
+ }
- return vnode;
- },
- mounted: function mounted() {
- this.referenceElm = this.$el;
- },
+ cell.disabled = typeof disabledDate === 'function' && disabledDate(new Date(time));
+ this.$set(row, this.showWeekNumber ? j + 1 : j, cell);
+ }
- methods: {
- addEventHandle: function addEventHandle(old, fn) {
- return old ? Array.isArray(old) ? old.concat(fn) : [old, fn] : fn;
- },
- concatClass: function concatClass(a, b) {
- if (a && a.indexOf(b) > -1) return a;
- return a ? b ? a + ' ' + b : a : b || '';
- },
- handleShowPopper: function handleShowPopper() {
- var _this3 = this;
+ if (this.selectionMode === 'week') {
+ var start = this.showWeekNumber ? 1 : 0;
+ var end = this.showWeekNumber ? 7 : 6;
+ var isWeekActive = this.isWeekActive(row[start + 1]);
- if (!this.expectedState || this.manual) return;
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this3.showPopper = true;
- }, this.openDelay);
+ row[start].inRange = isWeekActive;
+ row[start].start = isWeekActive;
+ row[end].inRange = isWeekActive;
+ row[end].end = isWeekActive;
+ }
+ }
+
+ rows.firstDayPosition = firstDayPosition;
+
+ return rows;
+ }
+ },
+
+ watch: {
+ 'rangeState.endDate': function rangeStateEndDate(newVal) {
+ this.markRange(newVal);
},
- handleClosePopper: function handleClosePopper() {
- if (this.enterable && this.expectedState || this.manual) return;
- clearTimeout(this.timeout);
- this.showPopper = false;
+ minDate: function minDate(newVal, oldVal) {
+ if (newVal && !oldVal) {
+ this.rangeState.selecting = true;
+ this.markRange(newVal);
+ } else if (!newVal) {
+ this.rangeState.selecting = false;
+ this.markRange(newVal);
+ } else {
+ this.markRange();
+ }
},
- setExpectedState: function setExpectedState(expectedState) {
- this.expectedState = expectedState;
+ maxDate: function maxDate(newVal, oldVal) {
+ if (newVal && !oldVal) {
+ this.rangeState.selecting = false;
+ this.markRange(newVal);
+ this.$emit('pick', {
+ minDate: this.minDate,
+ maxDate: this.maxDate
+ });
+ }
}
- }
- };
+ },
-/***/ },
-/* 194 */
-/***/ function(module, exports) {
+ data: function data() {
+ return {
+ tableRows: [[], [], [], [], [], []]
+ };
+ },
- module.exports = __webpack_require__(27);
-/***/ },
-/* 195 */
-/***/ function(module, exports, __webpack_require__) {
+ methods: {
+ getCellClasses: function getCellClasses(cell) {
+ var selectionMode = this.selectionMode;
+ var monthDate = this.monthDate;
- 'use strict';
+ 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);
+ }
- exports.__esModule = true;
+ if (selectionMode === 'day' && (cell.type === 'normal' || cell.type === 'today') && Number(this.year) === this.date.getFullYear() && this.month === this.date.getMonth() && monthDate === Number(cell.text)) {
+ classes.push('current');
+ }
- var _main = __webpack_require__(196);
+ if (cell.inRange && (cell.type === 'normal' || cell.type === 'today' || this.selectionMode === 'week')) {
+ classes.push('in-range');
- var _main2 = _interopRequireDefault(_main);
+ if (cell.start) {
+ classes.push('start-date');
+ }
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ if (cell.end) {
+ classes.push('end-date');
+ }
+ }
- exports.default = _main2.default;
+ if (cell.disabled) {
+ classes.push('disabled');
+ }
-/***/ },
-/* 196 */
-/***/ function(module, exports, __webpack_require__) {
+ return classes.join(' ');
+ },
+ getDateOfCell: function getDateOfCell(row, column) {
+ var startDate = this.startDate;
- 'use strict';
+ return new Date(startDate.getTime() + (row * 7 + (column - (this.showWeekNumber ? 1 : 0)) - this.offsetDay) * _util.DAY_DURATION);
+ },
+ getCellByDate: function getCellByDate(date) {
+ var startDate = this.startDate;
+ var rows = this.rows;
+ var index = (date - startDate) / _util.DAY_DURATION;
+ var row = rows[Math.floor(index / 7)];
- exports.__esModule = true;
- exports.MessageBox = undefined;
+ if (this.showWeekNumber) {
+ return row[index % 7 + 1];
+ } else {
+ return row[index % 7];
+ }
+ },
+ 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();
- 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; };
+ if (cell.type === 'prev-month') {
+ newDate.setMonth(month === 0 ? 11 : month - 1);
+ newDate.setFullYear(month === 0 ? year - 1 : year);
+ }
- var _vue = __webpack_require__(133);
+ if (cell.type === 'next-month') {
+ newDate.setMonth(month === 11 ? 0 : month + 1);
+ newDate.setFullYear(month === 11 ? year + 1 : year);
+ }
- var _vue2 = _interopRequireDefault(_vue);
+ newDate.setDate(parseInt(cell.text, 10));
- var _main = __webpack_require__(197);
+ return (0, _util.getWeekNumber)(newDate) === this.week;
+ },
+ markRange: function markRange(maxDate) {
+ var startDate = this.startDate;
+ if (!maxDate) {
+ maxDate = this.maxDate;
+ }
- var _main2 = _interopRequireDefault(_main);
+ var rows = this.rows;
+ var minDate = this.minDate;
+ 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 _merge = __webpack_require__(64);
+ var cell = row[j];
+ var index = i * 7 + j + (this.showWeekNumber ? -1 : 0);
+ var time = startDate.getTime() + _util.DAY_DURATION * (index - this.offsetDay);
- var _merge2 = _interopRequireDefault(_merge);
+ cell.inRange = minDate && time >= clearHours(minDate) && time <= clearHours(maxDate);
+ cell.start = minDate && time === clearHours(minDate.getTime());
+ cell.end = maxDate && time === clearHours(maxDate.getTime());
+ }
+ }
+ },
+ handleMouseMove: function handleMouseMove(event) {
+ if (!this.rangeState.selecting) return;
- var _vdom = __webpack_require__(194);
+ this.$emit('changerange', {
+ minDate: this.minDate,
+ maxDate: this.maxDate,
+ rangeState: this.rangeState
+ });
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var target = event.target;
+ if (target.tagName !== 'TD') return;
- var defaults = {
- title: undefined,
- message: '',
- type: '',
- showInput: false,
- showClose: true,
- modalFade: true,
- lockScroll: true,
- closeOnClickModal: true,
- closeOnPressEscape: true,
- inputValue: null,
- inputPlaceholder: '',
- inputPattern: null,
- inputValidator: null,
- inputErrorMessage: '',
- showConfirmButton: true,
- showCancelButton: false,
- confirmButtonPosition: 'right',
- confirmButtonHighlight: false,
- cancelButtonHighlight: false,
- confirmButtonText: '',
- cancelButtonText: '',
- confirmButtonClass: '',
- cancelButtonClass: '',
- customClass: '',
- beforeClose: null
- };
+ var column = target.cellIndex;
+ var row = target.parentNode.rowIndex - 1;
+ var _rangeState = this.rangeState,
+ oldRow = _rangeState.row,
+ oldColumn = _rangeState.column;
- var MessageBoxConstructor = _vue2.default.extend(_main2.default);
- var currentMsg = void 0,
- instance = void 0;
- var msgQueue = [];
+ if (oldRow !== row || oldColumn !== column) {
+ this.rangeState.row = row;
+ this.rangeState.column = column;
- var defaultCallback = function defaultCallback(action) {
- if (currentMsg) {
- var callback = currentMsg.callback;
- if (typeof callback === 'function') {
- if (instance.showInput) {
- callback(instance.inputValue, action);
- } else {
- callback(action);
- }
- }
- if (currentMsg.resolve) {
- if (action === 'confirm') {
- if (instance.showInput) {
- currentMsg.resolve({ value: instance.inputValue, action: action });
- } else {
- currentMsg.resolve(action);
- }
- } else if (action === 'cancel' && currentMsg.reject) {
- currentMsg.reject(action);
+ this.rangeState.endDate = this.getDateOfCell(row, column);
}
- }
- }
- };
+ },
+ handleClick: function handleClick(event) {
+ var target = event.target;
- var initInstance = function initInstance() {
- instance = new MessageBoxConstructor({
- el: document.createElement('div')
- });
+ if (target.tagName !== 'TD') return;
+ if ((0, _dom.hasClass)(target, 'disabled') || (0, _dom.hasClass)(target, 'week')) return;
- instance.callback = defaultCallback;
- };
+ var selectionMode = this.selectionMode;
- var showNextMsg = function showNextMsg() {
- if (!instance) {
- initInstance();
- }
- instance.action = '';
+ if (selectionMode === 'week') {
+ target = target.parentNode.cells[1];
+ }
- if (!instance.visible || instance.closeTimer) {
- if (msgQueue.length > 0) {
- (function () {
- currentMsg = msgQueue.shift();
+ var year = Number(this.year);
+ var month = Number(this.month);
- var options = currentMsg.options;
- for (var prop in options) {
- if (options.hasOwnProperty(prop)) {
- instance[prop] = options[prop];
- }
- }
- if (options.callback === undefined) {
- instance.callback = defaultCallback;
- }
+ var cellIndex = target.cellIndex;
+ var rowIndex = target.parentNode.rowIndex;
- var oldCb = instance.callback;
- instance.callback = function (action, instance) {
- oldCb(action, instance);
- showNextMsg();
- };
- if ((0, _vdom.isVNode)(instance.message)) {
- instance.$slots.default = [instance.message];
- instance.message = null;
+ var cell = this.rows[rowIndex - 1][cellIndex];
+ var text = cell.text;
+ var className = target.className;
+
+ var newDate = new Date(year, month, 1);
+
+ if (className.indexOf('prev') !== -1) {
+ if (month === 0) {
+ year = year - 1;
+ month = 11;
} else {
- delete instance.$slots.default;
+ month = month - 1;
}
- ['modal', 'showClose', 'closeOnClickModal', 'closeOnPressEscape'].forEach(function (prop) {
- if (instance[prop] === undefined) {
- instance[prop] = true;
- }
- });
- document.body.appendChild(instance.$el);
+ newDate.setFullYear(year);
+ newDate.setMonth(month);
+ } else if (className.indexOf('next') !== -1) {
+ if (month === 11) {
+ year = year + 1;
+ month = 0;
+ } else {
+ month = month + 1;
+ }
+ newDate.setFullYear(year);
+ newDate.setMonth(month);
+ }
- _vue2.default.nextTick(function () {
- instance.visible = true;
- });
- })();
- }
- }
- };
+ newDate.setDate(parseInt(text, 10));
- var MessageBox = function MessageBox(options, callback) {
- if (_vue2.default.prototype.$isServer) return;
- if (typeof options === 'string') {
- options = {
- message: options
- };
- if (arguments[1]) {
- options.title = arguments[1];
- }
- if (arguments[2]) {
- options.type = arguments[2];
- }
- } else if (options.callback && !callback) {
- callback = options.callback;
- }
+ if (this.selectionMode === 'range') {
+ if (this.minDate && this.maxDate) {
+ var minDate = new Date(newDate.getTime());
+ var maxDate = null;
- if (typeof Promise !== 'undefined') {
- return new Promise(function (resolve, reject) {
- // eslint-disable-line
- msgQueue.push({
- options: (0, _merge2.default)({}, defaults, MessageBox.defaults, options),
- callback: callback,
- resolve: resolve,
- reject: reject
- });
+ this.$emit('pick', { minDate: minDate, maxDate: maxDate }, false);
+ this.rangeState.selecting = true;
+ this.markRange(this.minDate);
+ } else if (this.minDate && !this.maxDate) {
+ if (newDate >= this.minDate) {
+ var _maxDate = new Date(newDate.getTime());
+ this.rangeState.selecting = false;
- showNextMsg();
- });
- } else {
- msgQueue.push({
- options: (0, _merge2.default)({}, defaults, MessageBox.defaults, options),
- callback: callback
- });
+ this.$emit('pick', {
+ minDate: this.minDate,
+ maxDate: _maxDate
+ });
+ } else {
+ var _minDate = new Date(newDate.getTime());
- showNextMsg();
- }
- };
+ this.$emit('pick', { minDate: _minDate, maxDate: this.maxDate }, false);
+ }
+ } else if (!this.minDate) {
+ var _minDate2 = new Date(newDate.getTime());
- MessageBox.setDefaults = function (defaults) {
- MessageBox.defaults = defaults;
- };
+ this.$emit('pick', { minDate: _minDate2, maxDate: this.maxDate }, false);
+ this.rangeState.selecting = true;
+ this.markRange(this.minDate);
+ }
+ } else if (selectionMode === 'day') {
+ this.$emit('pick', newDate);
+ } else if (selectionMode === 'week') {
+ var weekNumber = (0, _util.getWeekNumber)(newDate);
- MessageBox.alert = function (message, title, options) {
- if ((typeof title === 'undefined' ? 'undefined' : _typeof(title)) === 'object') {
- options = title;
- title = '';
- } else if (title === undefined) {
- title = '';
+ var value = newDate.getFullYear() + 'w' + weekNumber;
+ this.$emit('pick', {
+ year: newDate.getFullYear(),
+ week: weekNumber,
+ value: value,
+ date: newDate
+ });
+ }
+ }
}
- return MessageBox((0, _merge2.default)({
- title: title,
- message: message,
- $type: 'alert',
- closeOnPressEscape: false,
- closeOnClickModal: false
- }, options));
};
- MessageBox.confirm = function (message, title, options) {
- if ((typeof title === 'undefined' ? 'undefined' : _typeof(title)) === 'object') {
- options = title;
- title = '';
- } else if (title === undefined) {
- title = '';
- }
- return MessageBox((0, _merge2.default)({
- title: title,
- message: message,
- $type: 'confirm',
- showCancelButton: true
- }, options));
- };
+/***/ },
+/* 172 */
+/***/ function(module, exports) {
- MessageBox.prompt = function (message, title, options) {
- if ((typeof title === 'undefined' ? 'undefined' : _typeof(title)) === 'object') {
- options = title;
- title = '';
- } else if (title === undefined) {
- title = '';
- }
- return MessageBox((0, _merge2.default)({
- title: title,
- message: message,
- showCancelButton: true,
- showInput: true,
- $type: 'prompt'
- }, options));
- };
+ module.exports={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) {
+ return _c('th', [_vm._v(_vm._s(_vm.t('el.datepicker.weeks.' + week)))])
+ })], 2), _vm._l((_vm.rows), function(row) {
+ return _c('tr', {
+ staticClass: "el-date-table__row",
+ class: {
+ current: _vm.isWeekActive(row[1])
+ }
+ }, _vm._l((row), function(cell) {
+ return _c('td', {
+ class: _vm.getCellClasses(cell),
+ domProps: {
+ "textContent": _vm._s(cell.type === 'today' ? _vm.t('el.datepicker.today') : cell.text)
+ }
+ })
+ }))
+ })], 2)])
+ },staticRenderFns: []}
- MessageBox.close = function () {
- instance.visible = false;
- msgQueue = [];
- currentMsg = null;
- };
+/***/ },
+/* 173 */
+/***/ function(module, exports) {
- exports.default = MessageBox;
- exports.MessageBox = MessageBox;
+ module.exports={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-picker",
+ class: [{
+ 'has-sidebar': _vm.$slots.sidebar || _vm.shortcuts,
+ 'has-time': _vm.showTime
+ }, _vm.popperClass],
+ style: ({
+ width: _vm.width + 'px'
+ })
+ }, [_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) {
+ return _c('button', {
+ staticClass: "el-picker-panel__shortcut",
+ attrs: {
+ "type": "button"
+ },
+ on: {
+ "click": function($event) {
+ _vm.handleShortcutClick(shortcut)
+ }
+ }
+ }, [_vm._v(_vm._s(shortcut.text))])
+ })) : _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"
+ },
+ nativeOn: {
+ "change": function($event) {
+ _vm.visibleDate = $event.target.value
+ }
+ }
+ })], 1), _c('span', {
+ 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 = !_vm.timePickerVisible
+ }
+ },
+ nativeOn: {
+ "change": function($event) {
+ _vm.visibleTime = $event.target.value
+ }
+ }
+ }), _c('time-picker', {
+ ref: "timepicker",
+ attrs: {
+ "date": _vm.date,
+ "picker-width": _vm.pickerWidth,
+ "visible": _vm.timePickerVisible
+ },
+ on: {
+ "pick": _vm.handleTimePick,
+ "mounted": function($event) {
+ _vm.$refs.timepicker.format = _vm.timeFormat
+ }
+ }
+ })], 1)]) : _vm._e(), _c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.currentView !== 'time'),
+ expression: "currentView !== 'time'"
+ }],
+ staticClass: "el-date-picker__header"
+ }, [_c('button', {
+ staticClass: "el-picker-panel__icon-btn el-date-picker__prev-btn el-icon-d-arrow-left",
+ attrs: {
+ "type": "button"
+ },
+ 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"
+ },
+ on: {
+ "click": _vm.prevMonth
+ }
+ }), _c('span', {
+ staticClass: "el-date-picker__header-label",
+ 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'
+ },
+ 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"
+ },
+ 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"
+ },
+ 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: {
+ "year": _vm.year,
+ "month": _vm.month,
+ "date": _vm.date,
+ "week": _vm.week,
+ "selection-mode": _vm.selectionMode,
+ "first-day-of-week": _vm.firstDayOfWeek,
+ "disabled-date": _vm.disabledDate
+ },
+ on: {
+ "pick": _vm.handleDatePick
+ }
+ }), _c('year-table', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.currentView === 'year'),
+ expression: "currentView === 'year'"
+ }],
+ ref: "yearTable",
+ attrs: {
+ "year": _vm.year,
+ "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: {
+ "month": _vm.month,
+ "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('a', {
+ staticClass: "el-picker-panel__link-btn",
+ attrs: {
+ "href": "JavaScript:"
+ },
+ on: {
+ "click": _vm.changeToNow
+ }
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.now')))]), _c('button', {
+ staticClass: "el-picker-panel__btn",
+ attrs: {
+ "type": "button"
+ },
+ on: {
+ "click": _vm.confirm
+ }
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.confirm')))])])])])
+ },staticRenderFns: []}
/***/ },
-/* 197 */
+/* 174 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(198),
+ __webpack_require__(175),
/* template */
- __webpack_require__(199),
+ __webpack_require__(176),
/* styles */
null,
/* scopeId */
@@ -49872,503 +49110,777 @@ module.exports =
/***/ },
-/* 198 */
+/* 175 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _popup = __webpack_require__(14);
-
- var _popup2 = _interopRequireDefault(_popup);
+ var _util = __webpack_require__(153);
var _locale = __webpack_require__(10);
var _locale2 = _interopRequireDefault(_locale);
- var _input = __webpack_require__(20);
+ var _time = __webpack_require__(158);
- var _input2 = _interopRequireDefault(_input);
+ var _time2 = _interopRequireDefault(_time);
- var _button = __webpack_require__(31);
+ var _dateTable = __webpack_require__(170);
- var _button2 = _interopRequireDefault(_button);
+ var _dateTable2 = _interopRequireDefault(_dateTable);
- var _dom = __webpack_require__(44);
+ var _input = __webpack_require__(20);
- var _locale3 = __webpack_require__(111);
+ var _input2 = _interopRequireDefault(_input);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
-
- var typeMap = {
- success: 'circle-check',
- info: 'information',
- warning: 'warning',
- error: 'circle-cross'
- };
-
exports.default = {
- mixins: [_popup2.default, _locale2.default],
+ mixins: [_locale2.default],
- props: {
- modal: {
- default: true
+ computed: {
+ btnDisabled: function btnDisabled() {
+ return !(this.minDate && this.maxDate && !this.selecting);
},
- lockScroll: {
- default: true
+ leftLabel: function leftLabel() {
+ return this.date.getFullYear() + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + (this.date.getMonth() + 1));
},
- showClose: {
- type: Boolean,
- default: true
+ rightLabel: function rightLabel() {
+ return this.rightDate.getFullYear() + ' ' + this.t('el.datepicker.year') + ' ' + this.t('el.datepicker.month' + (this.rightDate.getMonth() + 1));
},
- closeOnClickModal: {
- default: true
+ leftYear: function leftYear() {
+ return this.date.getFullYear();
},
- closeOnPressEscape: {
- default: true
+ leftMonth: function leftMonth() {
+ return this.date.getMonth();
+ },
+ rightYear: function rightYear() {
+ return this.rightDate.getFullYear();
+ },
+ rightMonth: function rightMonth() {
+ return this.rightDate.getMonth();
+ },
+ minVisibleDate: function minVisibleDate() {
+ return this.minDate ? (0, _util.formatDate)(this.minDate) : '';
+ },
+ maxVisibleDate: function maxVisibleDate() {
+ return this.maxDate || this.minDate ? (0, _util.formatDate)(this.maxDate || this.minDate) : '';
+ },
+ minVisibleTime: function minVisibleTime() {
+ return this.minDate ? (0, _util.formatDate)(this.minDate, 'HH:mm:ss') : '';
+ },
+ maxVisibleTime: function maxVisibleTime() {
+ return this.maxDate || this.minDate ? (0, _util.formatDate)(this.maxDate || this.minDate, 'HH:mm:ss') : '';
+ },
+ rightDate: function rightDate() {
+ var newDate = new Date(this.date);
+ var month = newDate.getMonth();
+ newDate.setDate(1);
+
+ if (month === 11) {
+ newDate.setFullYear(newDate.getFullYear() + 1);
+ newDate.setMonth(0);
+ } else {
+ newDate.setMonth(month + 1);
+ }
+ return newDate;
}
},
- components: {
- ElInput: _input2.default,
- ElButton: _button2.default
+ data: function data() {
+ return {
+ popperClass: '',
+ minPickerWidth: 0,
+ maxPickerWidth: 0,
+ date: new Date(),
+ minDate: '',
+ maxDate: '',
+ rangeState: {
+ endDate: null,
+ selecting: false,
+ row: null,
+ column: null
+ },
+ showTime: false,
+ shortcuts: '',
+ value: '',
+ visible: '',
+ disabledDate: '',
+ firstDayOfWeek: 7,
+ minTimePickerVisible: false,
+ maxTimePickerVisible: false,
+ width: 0
+ };
},
- computed: {
- typeClass: function typeClass() {
- return this.type && typeMap[this.type] ? 'el-icon-' + typeMap[this.type] : '';
- },
- confirmButtonClasses: function confirmButtonClasses() {
- return 'el-button--primary ' + this.confirmButtonClass;
- },
- cancelButtonClasses: function cancelButtonClasses() {
- return '' + this.cancelButtonClass;
- }
- },
- methods: {
- getSafeClose: function getSafeClose() {
+ watch: {
+ showTime: function showTime(val) {
var _this = this;
- var currentId = this.uid;
- return function () {
- _this.$nextTick(function () {
- if (currentId === _this.uid) _this.doClose();
- });
- };
+ if (!val) return;
+ this.$nextTick(function (_) {
+ var minInputElm = _this.$refs.minInput.$el;
+ var maxInputElm = _this.$refs.maxInput.$el;
+ if (minInputElm) {
+ _this.minPickerWidth = minInputElm.getBoundingClientRect().width + 10;
+ }
+ if (maxInputElm) {
+ _this.maxPickerWidth = maxInputElm.getBoundingClientRect().width + 10;
+ }
+ });
},
- doClose: function doClose() {
+ minDate: function minDate() {
var _this2 = this;
- if (!this.visible) return;
- this.visible = false;
- this._closing = true;
+ this.$nextTick(function () {
+ if (_this2.maxDate && _this2.maxDate < _this2.minDate) {
+ var format = 'HH:mm:ss';
- this.onClose && this.onClose();
+ _this2.$refs.maxTimePicker.selectableRange = [[(0, _util.parseDate)((0, _util.formatDate)(_this2.minDate, format), format), (0, _util.parseDate)('23:59:59', format)]];
+ }
+ });
+ },
+ minTimePickerVisible: function minTimePickerVisible(val) {
+ var _this3 = this;
- if (this.lockScroll) {
- setTimeout(function () {
- if (_this2.modal && _this2.bodyOverflow !== 'hidden') {
- document.body.style.overflow = _this2.bodyOverflow;
- document.body.style.paddingRight = _this2.bodyPaddingRight;
- }
- _this2.bodyOverflow = null;
- _this2.bodyPaddingRight = null;
- }, 200);
- }
- this.opened = false;
+ if (val) this.$nextTick(function () {
+ return _this3.$refs.minTimePicker.ajustScrollTop();
+ });
+ },
+ maxTimePickerVisible: function maxTimePickerVisible(val) {
+ var _this4 = this;
- if (!this.transition) {
- this.doAfterClose();
- }
- if (this.action) this.callback(this.action, this);
+ if (val) this.$nextTick(function () {
+ return _this4.$refs.maxTimePicker.ajustScrollTop();
+ });
},
- handleWrapperClick: function handleWrapperClick() {
- if (this.closeOnClickModal) {
- this.handleAction('cancel');
+ value: function value(newVal) {
+ if (!newVal) {
+ this.minDate = null;
+ this.maxDate = null;
+ } else if (Array.isArray(newVal)) {
+ this.minDate = newVal[0] ? (0, _util.toDate)(newVal[0]) : null;
+ this.maxDate = newVal[1] ? (0, _util.toDate)(newVal[1]) : null;
+ if (this.minDate) this.date = new Date(this.minDate);
+ this.handleConfirm(true);
}
+ }
+ },
+
+ methods: {
+ handleClear: function handleClear() {
+ this.minDate = null;
+ this.maxDate = null;
+ this.handleConfirm(false);
},
- 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();
+ handleDateInput: function handleDateInput(event, type) {
+ var value = event.target.value;
+ var parsedValue = (0, _util.parseDate)(value, 'yyyy-MM-dd');
+
+ if (parsedValue) {
+ if (typeof this.disabledDate === 'function' && this.disabledDate(new Date(parsedValue))) {
+ return;
+ }
+ var target = new Date(type === 'min' ? this.minDate : this.maxDate);
+ if (target) {
+ target.setFullYear(parsedValue.getFullYear());
+ target.setMonth(parsedValue.getMonth(), parsedValue.getDate());
+ }
}
},
- validate: function validate() {
- if (this.$type === 'prompt') {
- var inputPattern = this.inputPattern;
- if (inputPattern && !inputPattern.test(this.inputValue || '')) {
- this.editorErrorMessage = this.inputErrorMessage || (0, _locale3.t)('el.messagebox.error');
- (0, _dom.addClass)(this.$refs.input.$el.querySelector('input'), 'invalid');
- return false;
+ handleChangeRange: function handleChangeRange(val) {
+ this.minDate = val.minDate;
+ this.maxDate = val.maxDate;
+ this.rangeState = val.rangeState;
+ },
+ handleDateChange: function handleDateChange(event, type) {
+ var value = event.target.value;
+ var parsedValue = (0, _util.parseDate)(value, 'yyyy-MM-dd');
+ if (parsedValue) {
+ var target = new Date(type === 'min' ? this.minDate : this.maxDate);
+ if (target) {
+ target.setFullYear(parsedValue.getFullYear());
+ target.setMonth(parsedValue.getMonth(), parsedValue.getDate());
}
- var inputValidator = this.inputValidator;
- if (typeof inputValidator === 'function') {
- var validateResult = inputValidator(this.inputValue);
- if (validateResult === false) {
- this.editorErrorMessage = this.inputErrorMessage || (0, _locale3.t)('el.messagebox.error');
- (0, _dom.addClass)(this.$refs.input.$el.querySelector('input'), 'invalid');
- return false;
+ if (type === 'min') {
+ if (target < this.maxDate) {
+ this.minDate = new Date(target.getTime());
}
- if (typeof validateResult === 'string') {
- this.editorErrorMessage = validateResult;
- return false;
+ } else {
+ if (target > this.minDate) {
+ this.maxDate = new Date(target.getTime());
+ if (this.minDate && this.minDate > this.maxDate) {
+ this.minDate = null;
+ }
}
}
}
- this.editorErrorMessage = '';
- (0, _dom.removeClass)(this.$refs.input.$el.querySelector('input'), 'invalid');
- return true;
- }
- },
-
- watch: {
- inputValue: {
- immediate: true,
- handler: function handler(val) {
- var _this3 = this;
-
- this.$nextTick(function (_) {
- if (_this3.$type === 'prompt' && val !== null) {
- _this3.validate();
+ },
+ handleTimeChange: function handleTimeChange(event, type) {
+ var value = event.target.value;
+ var parsedValue = (0, _util.parseDate)(value, 'HH:mm:ss');
+ if (parsedValue) {
+ var target = new Date(type === 'min' ? this.minDate : this.maxDate);
+ if (target) {
+ target.setHours(parsedValue.getHours());
+ target.setMinutes(parsedValue.getMinutes());
+ target.setSeconds(parsedValue.getSeconds());
+ }
+ if (type === 'min') {
+ if (target < this.maxDate) {
+ this.minDate = new Date(target.getTime());
}
- });
+ } else {
+ if (target > this.minDate) {
+ this.maxDate = new Date(target.getTime());
+ }
+ }
+ this.$refs[type + 'TimePicker'].value = target;
+ this[type + 'TimePickerVisible'] = false;
}
},
+ handleRangePick: function handleRangePick(val) {
+ var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
- 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();
- });
- }
- if (this.$type !== 'prompt') return;
- if (val) {
- setTimeout(function () {
- if (_this4.$refs.input && _this4.$refs.input.$el) {
- _this4.$refs.input.$el.querySelector('input').focus();
- }
- }, 500);
- } else {
- this.editorErrorMessage = '';
- (0, _dom.removeClass)(this.$refs.input.$el.querySelector('input'), 'invalid');
+ if (this.maxDate === val.maxDate && this.minDate === val.minDate) {
+ return;
}
- }
- },
-
- data: function data() {
- return {
- uid: 1,
- title: undefined,
- message: '',
- type: '',
- customClass: '',
- showInput: false,
- inputValue: null,
- inputPlaceholder: '',
- inputPattern: null,
- inputValidator: null,
- inputErrorMessage: '',
- showConfirmButton: true,
- showCancelButton: false,
- action: '',
- confirmButtonText: '',
- cancelButtonText: '',
- confirmButtonLoading: false,
- cancelButtonLoading: false,
- confirmButtonClass: '',
- confirmButtonDisabled: false,
- cancelButtonClass: '',
- editorErrorMessage: null,
- callback: null
- };
- }
- };
-
-/***/ },
-/* 199 */
-/***/ function(module, exports) {
-
- module.exports={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"
+ this.onPick && this.onPick(val);
+ this.maxDate = val.maxDate;
+ this.minDate = val.minDate;
+ if (!close || this.showTime) return;
+ this.handleConfirm();
},
- on: {
- "click": function($event) {
- if ($event.target !== $event.currentTarget) { return null; }
- _vm.handleWrapperClick($event)
- }
- }
- }, [_c('div', {
- staticClass: "el-message-box",
- class: _vm.customClass
- }, [(_vm.title !== undefined) ? _c('div', {
- staticClass: "el-message-box__header"
- }, [_c('div', {
- staticClass: "el-message-box__title"
- }, [_vm._v(_vm._s(_vm.title))]), (_vm.showClose) ? _c('button', {
- staticClass: "el-message-box__headerbtn",
- attrs: {
- "type": "button",
- "aria-label": "Close"
+ changeToToday: function changeToToday() {
+ this.date = new Date();
},
- on: {
- "click": function($event) {
- _vm.handleAction('cancel')
+ handleShortcutClick: function handleShortcutClick(shortcut) {
+ if (shortcut.onClick) {
+ shortcut.onClick(this);
}
- }
- }, [_c('i', {
- staticClass: "el-message-box__close el-icon-close"
- })]) : _vm._e()]) : _vm._e(), (_vm.message !== '') ? _c('div', {
- staticClass: "el-message-box__content"
- }, [_c('div', {
- staticClass: "el-message-box__status",
- class: [_vm.typeClass]
- }), _c('div', {
- staticClass: "el-message-box__message",
- style: ({
- 'margin-left': _vm.typeClass ? '50px' : '0'
- })
- }, [_vm._t("default", [_c('p', [_vm._v(_vm._s(_vm.message))])])], 2), _c('div', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.showInput),
- expression: "showInput"
- }],
- staticClass: "el-message-box__input"
- }, [_c('el-input', {
- ref: "input",
- attrs: {
- "placeholder": _vm.inputPlaceholder
},
- nativeOn: {
- "keyup": function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
- _vm.handleAction('confirm')
- }
+ resetView: function resetView() {
+ this.minTimePickerVisible = false;
+ this.maxTimePickerVisible = false;
},
- 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)]) : _vm._e(), _c('div', {
- staticClass: "el-message-box__btns"
- }, [_c('el-button', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.showCancelButton),
- expression: "showCancelButton"
- }],
- class: [_vm.cancelButtonClasses],
- attrs: {
- "loading": _vm.cancelButtonLoading
+ setTime: function setTime(date, value) {
+ var oldDate = new Date(date.getTime());
+ var hour = value.getHours();
+ var minute = value.getMinutes();
+ var second = value.getSeconds();
+ oldDate.setHours(hour);
+ oldDate.setMinutes(minute);
+ oldDate.setSeconds(second);
+ return new Date(oldDate.getTime());
},
- nativeOn: {
- "click": function($event) {
- _vm.handleAction('cancel')
+ handleMinTimePick: function handleMinTimePick(value, visible, first) {
+ this.minDate = this.minDate || new Date();
+ if (value) {
+ this.minDate = this.setTime(this.minDate, value);
+ }
+
+ if (!first) {
+ this.minTimePickerVisible = visible;
}
- }
- }, [_vm._v("\n " + _vm._s(_vm.cancelButtonText || _vm.t('el.messagebox.cancel')) + "\n ")]), _c('el-button', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.showConfirmButton),
- expression: "showConfirmButton"
- }],
- ref: "confirm",
- class: [_vm.confirmButtonClasses],
- attrs: {
- "loading": _vm.confirmButtonLoading
},
- nativeOn: {
- "click": function($event) {
- _vm.handleAction('confirm')
+ handleMaxTimePick: function handleMaxTimePick(value, visible, first) {
+ if (!this.maxDate) {
+ var now = new Date();
+ if (now >= this.minDate) {
+ this.maxDate = new Date();
+ }
}
- }
- }, [_vm._v("\n " + _vm._s(_vm.confirmButtonText || _vm.t('el.messagebox.confirm')) + "\n ")])], 1)])])])
- },staticRenderFns: []}
-
-/***/ },
-/* 200 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _breadcrumb = __webpack_require__(201);
- var _breadcrumb2 = _interopRequireDefault(_breadcrumb);
+ if (this.maxDate && value) {
+ this.maxDate = this.setTime(this.maxDate, value);
+ }
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _breadcrumb2.default.install = function (Vue) {
- Vue.component(_breadcrumb2.default.name, _breadcrumb2.default);
- };
-
- exports.default = _breadcrumb2.default;
-
-/***/ },
-/* 201 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(202),
- /* template */
- __webpack_require__(203),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
-
-/***/ },
-/* 202 */
-/***/ function(module, exports) {
+ if (!first) {
+ this.maxTimePickerVisible = visible;
+ }
+ },
+ prevMonth: function prevMonth() {
+ this.date = (0, _util.prevMonth)(this.date);
+ },
+ nextMonth: function nextMonth() {
+ this.date = (0, _util.nextMonth)(this.date);
+ },
+ nextYear: function nextYear() {
+ var date = this.date;
+ date.setFullYear(date.getFullYear() + 1);
+ this.resetDate();
+ },
+ prevYear: function prevYear() {
+ var date = this.date;
+ date.setFullYear(date.getFullYear() - 1);
+ this.resetDate();
+ },
+ handleConfirm: function handleConfirm() {
+ var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- 'use strict';
+ this.$emit('pick', [this.minDate, this.maxDate], visible);
+ },
+ resetDate: function resetDate() {
+ this.date = new Date(this.date);
+ }
+ },
- exports.__esModule = true;
+ components: { TimePicker: _time2.default, DateTable: _dateTable2.default, ElInput: _input2.default }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
//
//
//
//
//
-
- exports.default = {
- name: 'ElBreadcrumb',
-
- props: {
- separator: {
- type: String,
- default: '/'
- }
- }
- };
/***/ },
-/* 203 */
+/* 176 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-breadcrumb"
- }, [_vm._t("default")], 2)
+ 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",
+ class: [{
+ 'has-sidebar': _vm.$slots.sidebar || _vm.shortcuts,
+ 'has-time': _vm.showTime
+ }, _vm.popperClass],
+ style: ({
+ width: _vm.width + 'px'
+ })
+ }, [_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) {
+ return _c('button', {
+ staticClass: "el-picker-panel__shortcut",
+ attrs: {
+ "type": "button"
+ },
+ on: {
+ "click": function($event) {
+ _vm.handleShortcutClick(shortcut)
+ }
+ }
+ }, [_vm._v(_vm._s(shortcut.text))])
+ })) : _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",
+ "placeholder": _vm.t('el.datepicker.startDate'),
+ "value": _vm.minVisibleDate
+ },
+ nativeOn: {
+ "input": function($event) {
+ _vm.handleDateInput($event, 'min')
+ },
+ "change": function($event) {
+ _vm.handleDateChange($event, 'min')
+ }
+ }
+ })], 1), _c('span', {
+ staticClass: "el-date-range-picker__time-picker-wrap"
+ }, [_c('el-input', {
+ staticClass: "el-date-range-picker__editor",
+ attrs: {
+ "size": "small",
+ "placeholder": _vm.t('el.datepicker.startTime'),
+ "value": _vm.minVisibleTime
+ },
+ on: {
+ "focus": function($event) {
+ _vm.minTimePickerVisible = !_vm.minTimePickerVisible
+ }
+ },
+ nativeOn: {
+ "change": function($event) {
+ _vm.handleTimeChange($event, 'min')
+ }
+ }
+ }), _c('time-picker', {
+ ref: "minTimePicker",
+ attrs: {
+ "picker-width": _vm.minPickerWidth,
+ "date": _vm.minDate,
+ "visible": _vm.minTimePickerVisible
+ },
+ on: {
+ "pick": _vm.handleMinTimePick
+ }
+ })], 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",
+ "placeholder": _vm.t('el.datepicker.endDate'),
+ "value": _vm.maxVisibleDate,
+ "readonly": !_vm.minDate
+ },
+ nativeOn: {
+ "input": function($event) {
+ _vm.handleDateInput($event, 'max')
+ },
+ "change": function($event) {
+ _vm.handleDateChange($event, 'max')
+ }
+ }
+ })], 1), _c('span', {
+ staticClass: "el-date-range-picker__time-picker-wrap"
+ }, [_c('el-input', {
+ ref: "maxInput",
+ staticClass: "el-date-range-picker__editor",
+ attrs: {
+ "size": "small",
+ "placeholder": _vm.t('el.datepicker.endTime'),
+ "value": _vm.maxVisibleTime,
+ "readonly": !_vm.minDate
+ },
+ on: {
+ "focus": function($event) {
+ _vm.minDate && (_vm.maxTimePickerVisible = !_vm.maxTimePickerVisible)
+ }
+ },
+ nativeOn: {
+ "change": function($event) {
+ _vm.handleTimeChange($event, 'max')
+ }
+ }
+ }), _c('time-picker', {
+ ref: "maxTimePicker",
+ attrs: {
+ "picker-width": _vm.maxPickerWidth,
+ "date": _vm.maxDate,
+ "visible": _vm.maxTimePickerVisible
+ },
+ on: {
+ "pick": _vm.handleMaxTimePick
+ }
+ })], 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.prevYear
+ }
+ }), _c('button', {
+ staticClass: "el-picker-panel__icon-btn el-icon-arrow-left",
+ attrs: {
+ "type": "button"
+ },
+ on: {
+ "click": _vm.prevMonth
+ }
+ }), _c('div', [_vm._v(_vm._s(_vm.leftLabel))])]), _c('date-table', {
+ attrs: {
+ "selection-mode": "range",
+ "date": _vm.date,
+ "year": _vm.leftYear,
+ "month": _vm.leftMonth,
+ "min-date": _vm.minDate,
+ "max-date": _vm.maxDate,
+ "range-state": _vm.rangeState,
+ "disabled-date": _vm.disabledDate,
+ "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"
+ }, [_c('button', {
+ staticClass: "el-picker-panel__icon-btn el-icon-d-arrow-right",
+ attrs: {
+ "type": "button"
+ },
+ on: {
+ "click": _vm.nextYear
+ }
+ }), _c('button', {
+ staticClass: "el-picker-panel__icon-btn el-icon-arrow-right",
+ attrs: {
+ "type": "button"
+ },
+ on: {
+ "click": _vm.nextMonth
+ }
+ }), _c('div', [_vm._v(_vm._s(_vm.rightLabel))])]), _c('date-table', {
+ attrs: {
+ "selection-mode": "range",
+ "date": _vm.rightDate,
+ "year": _vm.rightYear,
+ "month": _vm.rightMonth,
+ "min-date": _vm.minDate,
+ "max-date": _vm.maxDate,
+ "range-state": _vm.rangeState,
+ "disabled-date": _vm.disabledDate,
+ "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('a', {
+ staticClass: "el-picker-panel__link-btn",
+ on: {
+ "click": _vm.handleClear
+ }
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.clear')))]), _c('button', {
+ staticClass: "el-picker-panel__btn",
+ attrs: {
+ "type": "button",
+ "disabled": _vm.btnDisabled
+ },
+ on: {
+ "click": function($event) {
+ _vm.handleConfirm()
+ }
+ }
+ }, [_vm._v(_vm._s(_vm.t('el.datepicker.confirm')))])]) : _vm._e()])])
},staticRenderFns: []}
/***/ },
-/* 204 */
+/* 177 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _breadcrumbItem = __webpack_require__(205);
+ var _timeSelect = __webpack_require__(178);
- var _breadcrumbItem2 = _interopRequireDefault(_breadcrumbItem);
+ var _timeSelect2 = _interopRequireDefault(_timeSelect);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _breadcrumbItem2.default.install = function (Vue) {
- Vue.component(_breadcrumbItem2.default.name, _breadcrumbItem2.default);
+ _timeSelect2.default.install = function (Vue) {
+ Vue.component(_timeSelect2.default.name, _timeSelect2.default);
};
- exports.default = _breadcrumbItem2.default;
+ exports.default = _timeSelect2.default;
/***/ },
-/* 205 */
+/* 178 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _picker = __webpack_require__(151);
+
+ var _picker2 = _interopRequireDefault(_picker);
+
+ var _timeSelect = __webpack_require__(179);
+
+ var _timeSelect2 = _interopRequireDefault(_timeSelect);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ exports.default = {
+ mixins: [_picker2.default],
+
+ name: 'ElTimeSelect',
+
+ beforeCreate: function beforeCreate() {
+ this.type = 'time-select';
+ this.panel = _timeSelect2.default;
+ }
+ };
+
+/***/ },
+/* 179 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(206),
+ __webpack_require__(180),
/* template */
- __webpack_require__(207),
+ __webpack_require__(181),
/* styles */
null,
/* scopeId */
@@ -50381,254 +49893,315 @@ module.exports =
/***/ },
-/* 206 */
-/***/ function(module, exports) {
+/* 180 */
+/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- //
- //
- //
- //
- //
-
- exports.default = {
- name: 'ElBreadcrumbItem',
- props: {
- to: {},
- replace: Boolean
- },
- data: function data() {
- return {
- separator: ''
- };
- },
- mounted: function mounted() {
- var _this = this;
- this.separator = this.$parent.separator;
- var self = this;
- if (this.to) {
- var link = this.$refs.link;
- link.addEventListener('click', function (_) {
- var to = _this.to;
- self.replace ? self.$router.replace(to) : self.$router.push(to);
- });
- }
- }
- };
+ var _scrollbar = __webpack_require__(25);
-/***/ },
-/* 207 */
-/***/ function(module, exports) {
+ var _scrollbar2 = _interopRequireDefault(_scrollbar);
- module.exports={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",
- staticClass: "el-breadcrumb__item__inner"
- }, [_vm._t("default")], 2), _c('span', {
- staticClass: "el-breadcrumb__separator"
- }, [_vm._v(_vm._s(_vm.separator))])])
- },staticRenderFns: []}
+ var _scrollIntoView = __webpack_require__(112);
-/***/ },
-/* 208 */
-/***/ function(module, exports, __webpack_require__) {
+ var _scrollIntoView2 = _interopRequireDefault(_scrollIntoView);
- 'use strict';
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var _form = __webpack_require__(209);
+ 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);
- var _form2 = _interopRequireDefault(_form);
+ return {
+ hours: hours,
+ minutes: minutes
+ };
+ }
+ /* istanbul ignore next */
+ return null;
+ };
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var compareTime = function compareTime(time1, time2) {
+ var value1 = parseTime(time1);
+ var value2 = parseTime(time2);
- /* istanbul ignore next */
- _form2.default.install = function (Vue) {
- Vue.component(_form2.default.name, _form2.default);
- };
+ var minutes1 = value1.minutes + value1.hours * 60;
+ var minutes2 = value2.minutes + value2.hours * 60;
- exports.default = _form2.default;
+ if (minutes1 === minutes2) {
+ return 0;
+ }
-/***/ },
-/* 209 */
-/***/ function(module, exports, __webpack_require__) {
+ return minutes1 > minutes2 ? 1 : -1;
+ };
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(210),
- /* template */
- __webpack_require__(211),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ var formatTime = function formatTime(time) {
+ return (time.hours < 10 ? '0' + time.hours : time.hours) + ':' + (time.minutes < 10 ? '0' + time.minutes : time.minutes);
+ };
- module.exports = Component.exports
+ var nextTime = function nextTime(time, step) {
+ var timeValue = parseTime(time);
+ var stepValue = parseTime(step);
+ var next = {
+ hours: timeValue.hours,
+ minutes: timeValue.minutes
+ };
-/***/ },
-/* 210 */
-/***/ function(module, exports, __webpack_require__) {
+ next.minutes += stepValue.minutes;
+ next.hours += stepValue.hours;
- 'use strict';
+ next.hours += Math.floor(next.minutes / 60);
+ next.minutes = next.minutes % 60;
- exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
+ return formatTime(next);
+ };
exports.default = {
- name: 'ElForm',
+ components: { ElScrollbar: _scrollbar2.default },
- componentName: 'ElForm',
+ watch: {
+ value: function value(val) {
+ var _this = this;
- props: {
- model: Object,
- rules: Object,
- labelPosition: String,
- labelWidth: String,
- labelSuffix: {
- type: String,
- default: ''
- },
- inline: Boolean,
- showMessage: {
- type: Boolean,
- default: true
+ if (!val) return;
+ if (this.minTime && compareTime(val, this.minTime) < 0) {
+ this.$emit('pick');
+ } else if (this.maxTime && compareTime(val, this.maxTime) > 0) {
+ this.$emit('pick');
+ }
+ this.$nextTick(function () {
+ return _this.scrollToOption();
+ });
}
},
- watch: {
- rules: function rules() {
- this.validate();
+
+ methods: {
+ handleClick: function handleClick(item) {
+ if (!item.disabled) {
+ this.$emit('pick', item.value);
+ }
+ },
+ handleClear: function handleClear() {
+ this.$emit('pick');
+ },
+ scrollToOption: function scrollToOption() {
+ var className = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'selected';
+
+ var menu = this.$refs.popper.querySelector('.el-picker-panel__content');
+ (0, _scrollIntoView2.default)(menu, menu.getElementsByClassName(className)[0]);
+ },
+ handleMenuEnter: function handleMenuEnter() {
+ var _this2 = this;
+
+ this.$nextTick(function () {
+ return _this2.scrollToOption();
+ });
}
},
+
data: function data() {
return {
- fields: []
+ popperClass: '',
+ start: '09:00',
+ end: '18:00',
+ step: '00:30',
+ value: '',
+ visible: false,
+ minTime: '',
+ maxTime: '',
+ width: 0
};
},
- 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) {
- ("production") !== 'production' && console.warn('[Element Warn][Form]model is required for resetFields to work.');
- return;
- }
- this.fields.forEach(function (field) {
- field.resetField();
- });
- },
- validate: function validate(callback) {
- var _this2 = this;
+ computed: {
+ items: function items() {
+ var start = this.start;
+ var end = this.end;
+ var step = this.step;
- if (!this.model) {
- console.warn('[Element Warn][Form]model is required for validate to work!');
- return;
- };
- var valid = true;
- var count = 0;
- // 如果需要验证的fields为空,调用验证时立刻返回callback
- if (this.fields.length === 0 && callback) {
- callback(true);
- }
- this.fields.forEach(function (field, index) {
- field.validate('', function (errors) {
- if (errors) {
- valid = false;
- }
- if (typeof callback === 'function' && ++count === _this2.fields.length) {
- callback(valid);
- }
- });
- });
- },
- validateField: function validateField(prop, cb) {
- var field = this.fields.filter(function (field) {
- return field.prop === prop;
- })[0];
- if (!field) {
- throw new Error('must call validateField with valid prop string!');
+ 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);
+ }
}
- field.validate('', cb);
+ return result;
}
}
};
/***/ },
-/* 211 */
+/* 181 */
/***/ function(module, exports) {
module.exports={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
+ return _c('transition', {
+ attrs: {
+ "name": "el-zoom-in-top"
+ },
+ on: {
+ "before-enter": _vm.handleMenuEnter,
+ "after-leave": function($event) {
+ _vm.$emit('dodestroy')
}
- ]
- }, [_vm._t("default")], 2)
+ }
+ }, [_c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.visible),
+ expression: "visible"
+ }],
+ ref: "popper",
+ staticClass: "el-picker-panel time-select",
+ 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', {
+ staticClass: "time-select-item",
+ class: {
+ selected: _vm.value === item.value, disabled: item.disabled
+ },
+ attrs: {
+ "disabled": item.disabled
+ },
+ on: {
+ "click": function($event) {
+ _vm.handleClick(item)
+ }
+ }
+ }, [_vm._v(_vm._s(item.value))])
+ }))], 1)])
},staticRenderFns: []}
/***/ },
-/* 212 */
+/* 182 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _formItem = __webpack_require__(213);
+ var _timePicker = __webpack_require__(183);
- var _formItem2 = _interopRequireDefault(_formItem);
+ var _timePicker2 = _interopRequireDefault(_timePicker);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _formItem2.default.install = function (Vue) {
- Vue.component(_formItem2.default.name, _formItem2.default);
+ _timePicker2.default.install = function (Vue) {
+ Vue.component(_timePicker2.default.name, _timePicker2.default);
};
- exports.default = _formItem2.default;
+ exports.default = _timePicker2.default;
/***/ },
-/* 213 */
+/* 183 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _picker = __webpack_require__(151);
+
+ var _picker2 = _interopRequireDefault(_picker);
+
+ var _time = __webpack_require__(158);
+
+ var _time2 = _interopRequireDefault(_time);
+
+ var _timeRange = __webpack_require__(184);
+
+ var _timeRange2 = _interopRequireDefault(_timeRange);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ exports.default = {
+ mixins: [_picker2.default],
+
+ name: 'ElTimePicker',
+
+ props: {
+ isRange: Boolean
+ },
+
+ data: function data() {
+ return {
+ type: ''
+ };
+ },
+
+
+ watch: {
+ isRange: function isRange(_isRange) {
+ if (this.picker) {
+ this.unmountPicker();
+ this.type = _isRange ? 'timerange' : 'time';
+ this.panel = _isRange ? _timeRange2.default : _time2.default;
+ this.mountPicker();
+ } else {
+ this.type = _isRange ? 'timerange' : 'time';
+ this.panel = _isRange ? _timeRange2.default : _time2.default;
+ }
+ }
+ },
+
+ created: function created() {
+ this.type = this.isRange ? 'timerange' : 'time';
+ this.panel = this.isRange ? _timeRange2.default : _time2.default;
+ }
+ };
+
+/***/ },
+/* 184 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(214),
+ __webpack_require__(185),
/* template */
- __webpack_require__(216),
+ __webpack_require__(186),
/* styles */
null,
/* scopeId */
@@ -50641,23 +50214,67 @@ module.exports =
/***/ },
-/* 214 */
+/* 185 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _asyncValidator = __webpack_require__(215);
+ var _util = __webpack_require__(153);
- var _asyncValidator2 = _interopRequireDefault(_asyncValidator);
+ var _locale = __webpack_require__(10);
- var _emitter = __webpack_require__(15);
+ var _locale2 = _interopRequireDefault(_locale);
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _timeSpinner = __webpack_require__(160);
+
+ var _timeSpinner2 = _interopRequireDefault(_timeSpinner);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var MIN_TIME = (0, _util.parseDate)('00:00:00', 'HH:mm:ss'); //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
//
//
//
@@ -50676,304 +50293,307 @@ module.exports =
//
//
- function noop() {}
-
- function getPropByPath(obj, path) {
- var tempObj = obj;
- path = path.replace(/\[(\w+)\]/g, '.$1');
- path = path.replace(/^\./, '');
+ var MAX_TIME = (0, _util.parseDate)('23:59:59', 'HH:mm:ss');
+ var isDisabled = function isDisabled(minTime, maxTime) {
+ var minValue = minTime.getHours() * 3600 + minTime.getMinutes() * 60 + minTime.getSeconds();
+ var maxValue = maxTime.getHours() * 3600 + maxTime.getMinutes() * 60 + maxTime.getSeconds();
- var keyArr = path.split('.');
- var i = 0;
+ return minValue > maxValue;
+ };
+ var clacTime = function clacTime(time) {
+ time = Array.isArray(time) ? time : [time];
+ var minTime = time[0] || new Date();
+ var date = new Date();
+ date.setHours(date.getHours() + 1);
+ var maxTime = time[1] || date;
- for (var len = keyArr.length; i < len - 1; ++i) {
- var key = keyArr[i];
- if (key in tempObj) {
- tempObj = tempObj[key];
- } else {
- throw new Error('please transfer a valid prop path to form item!');
- }
- }
- return {
- o: tempObj,
- k: keyArr[i],
- v: tempObj[keyArr[i]]
- };
- }
+ if (minTime > maxTime) return clacTime();
+ return { minTime: minTime, maxTime: maxTime };
+ };
exports.default = {
- name: 'ElFormItem',
+ mixins: [_locale2.default],
- componentName: 'ElFormItem',
+ components: { TimeSpinner: _timeSpinner2.default },
- mixins: [_emitter2.default],
+ computed: {
+ showSeconds: function showSeconds() {
+ return (this.format || '').indexOf('ss') !== -1;
+ }
+ },
- props: {
- label: String,
- labelWidth: String,
- prop: String,
- required: Boolean,
- rules: [Object, Array],
- error: String,
- validateStatus: String,
- showMessage: {
- type: Boolean,
- default: true
- }
- },
- watch: {
- error: function error(value) {
- this.validateMessage = value;
- this.validateState = value ? 'error' : '';
- },
- validateStatus: function validateStatus(value) {
- this.validateState = value;
- }
- },
- computed: {
- 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) {
- 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: {
- cache: false,
- get: function get() {
- var model = this.form.model;
- if (!model || !this.prop) {
- return;
- }
-
- var path = this.prop;
- if (path.indexOf(':') !== -1) {
- path = path.replace(/:/, '.');
- }
-
- return getPropByPath(model, path).v;
- }
- },
- isRequired: function isRequired() {
- var rules = this.getRules();
- var isRequired = false;
+ props: ['value'],
- if (rules && rules.length) {
- rules.every(function (rule) {
- if (rule.required) {
- isRequired = true;
- return false;
- }
- return true;
- });
- }
- return isRequired;
- }
- },
data: function data() {
+ var time = clacTime(this.$options.defaultValue);
+
return {
- validateState: '',
- validateMessage: '',
- validateDisabled: false,
- validator: {},
- isNested: false
+ popperClass: '',
+ minTime: time.minTime,
+ maxTime: time.maxTime,
+ btnDisabled: isDisabled(time.minTime, time.maxTime),
+ maxHours: time.maxTime.getHours(),
+ maxMinutes: time.maxTime.getMinutes(),
+ maxSeconds: time.maxTime.getSeconds(),
+ minHours: time.minTime.getHours(),
+ minMinutes: time.minTime.getMinutes(),
+ minSeconds: time.minTime.getSeconds(),
+ format: 'HH:mm:ss',
+ visible: false,
+ width: 0
};
},
- methods: {
- validate: function validate(trigger) {
+
+ watch: {
+ value: function value(newVal) {
var _this = this;
- var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : noop;
+ this.panelCreated();
+ this.$nextTick(function (_) {
+ return _this.ajustScrollTop();
+ });
+ }
+ },
- var rules = this.getFilteredRule(trigger);
- if (!rules || rules.length === 0) {
- callback();
- return true;
+ methods: {
+ panelCreated: function panelCreated() {
+ var time = clacTime(this.value);
+ if (time.minTime === this.minTime && time.maxTime === this.maxTime) {
+ return;
}
- this.validateState = 'validating';
-
- var descriptor = {};
- descriptor[this.prop] = rules;
-
- var validator = new _asyncValidator2.default(descriptor);
- var model = {};
-
- model[this.prop] = this.fieldValue;
-
- validator.validate(model, { firstFields: true }, function (errors, fields) {
- _this.validateState = !errors ? 'success' : 'error';
- _this.validateMessage = errors ? errors[0].message : '';
-
- callback(_this.validateMessage);
+ this.handleMinChange({
+ hours: time.minTime.getHours(),
+ minutes: time.minTime.getMinutes(),
+ seconds: time.minTime.getSeconds()
+ });
+ this.handleMaxChange({
+ hours: time.maxTime.getHours(),
+ minutes: time.maxTime.getMinutes(),
+ seconds: time.maxTime.getSeconds()
});
},
- resetField: function resetField() {
- this.validateState = '';
- this.validateMessage = '';
-
- var model = this.form.model;
- var value = this.fieldValue;
- var path = this.prop;
- if (path.indexOf(':') !== -1) {
- path = path.replace(/:/, '.');
+ handleClear: function handleClear() {
+ this.handleCancel();
+ },
+ handleCancel: function handleCancel() {
+ this.$emit('pick');
+ },
+ handleChange: function handleChange() {
+ if (this.minTime > this.maxTime) return;
+ MIN_TIME.setFullYear(this.minTime.getFullYear());
+ MIN_TIME.setMonth(this.minTime.getMonth(), this.minTime.getDate());
+ MAX_TIME.setFullYear(this.maxTime.getFullYear());
+ MAX_TIME.setMonth(this.maxTime.getMonth(), this.maxTime.getDate());
+ this.$refs.minSpinner.selectableRange = [[MIN_TIME, this.maxTime]];
+ this.$refs.maxSpinner.selectableRange = [[this.minTime, MAX_TIME]];
+ this.handleConfirm(true);
+ },
+ handleMaxChange: function handleMaxChange(date) {
+ if (date.hours !== undefined) {
+ this.maxTime.setHours(date.hours);
+ this.maxHours = this.maxTime.getHours();
}
-
- var prop = getPropByPath(model, path);
-
- if (Array.isArray(value)) {
- this.validateDisabled = true;
- prop.o[prop.k] = [].concat(this.initialValue);
- } else {
- this.validateDisabled = true;
- prop.o[prop.k] = this.initialValue;
+ if (date.minutes !== undefined) {
+ this.maxTime.setMinutes(date.minutes);
+ this.maxMinutes = this.maxTime.getMinutes();
+ }
+ if (date.seconds !== undefined) {
+ this.maxTime.setSeconds(date.seconds);
+ this.maxSeconds = this.maxTime.getSeconds();
}
+ this.handleChange();
},
- getRules: function getRules() {
- var formRules = this.form.rules;
- var selfRuels = this.rules;
-
- formRules = formRules ? formRules[this.prop] : [];
+ handleMinChange: function handleMinChange(date) {
+ if (date.hours !== undefined) {
+ this.minTime.setHours(date.hours);
+ this.minHours = this.minTime.getHours();
+ }
+ if (date.minutes !== undefined) {
+ this.minTime.setMinutes(date.minutes);
+ this.minMinutes = this.minTime.getMinutes();
+ }
+ if (date.seconds !== undefined) {
+ this.minTime.setSeconds(date.seconds);
+ this.minSeconds = this.minTime.getSeconds();
+ }
- return [].concat(selfRuels || formRules || []);
+ this.handleChange();
},
- getFilteredRule: function getFilteredRule(trigger) {
- var rules = this.getRules();
-
- return rules.filter(function (rule) {
- return !rule.trigger || rule.trigger.indexOf(trigger) !== -1;
- });
+ setMinSelectionRange: function setMinSelectionRange(start, end) {
+ this.$emit('select-range', start, end);
},
- onFieldBlur: function onFieldBlur() {
- this.validate('blur');
+ setMaxSelectionRange: function setMaxSelectionRange(start, end) {
+ this.$emit('select-range', start + 11, end + 11);
},
- onFieldChange: function onFieldChange() {
- if (this.validateDisabled) {
- this.validateDisabled = false;
- return;
- }
-
- this.validate('change');
- }
- },
- mounted: function mounted() {
- if (this.prop) {
- this.dispatch('ElForm', 'el.form.addField', [this]);
+ handleConfirm: function handleConfirm() {
+ var visible = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
+ var first = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
- var initialValue = this.fieldValue;
- if (Array.isArray(initialValue)) {
- initialValue = [].concat(initialValue);
- }
- Object.defineProperty(this, 'initialValue', {
- value: initialValue
- });
+ var minSelectableRange = this.$refs.minSpinner.selectableRange;
+ var maxSelectableRange = this.$refs.maxSpinner.selectableRange;
- var rules = this.getRules();
+ this.minTime = (0, _util.limitRange)(this.minTime, minSelectableRange);
+ this.maxTime = (0, _util.limitRange)(this.maxTime, maxSelectableRange);
- if (rules.length) {
- this.$on('el.form.blur', this.onFieldBlur);
- this.$on('el.form.change', this.onFieldChange);
- }
+ if (first) return;
+ this.$emit('pick', [this.minTime, this.maxTime], visible, first);
+ },
+ ajustScrollTop: function ajustScrollTop() {
+ this.$refs.minSpinner.ajustScrollTop();
+ this.$refs.maxSpinner.ajustScrollTop();
}
},
- beforeDestroy: function beforeDestroy() {
- this.dispatch('ElForm', 'el.form.removeField', [this]);
- }
- };
-/***/ },
-/* 215 */
-/***/ function(module, exports) {
+ mounted: function mounted() {
+ var _this2 = this;
- module.exports = __webpack_require__(55);
+ this.$nextTick(function () {
+ return _this2.handleConfirm(true, true);
+ });
+ }
+ };
/***/ },
-/* 216 */
+/* 186 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-form-item",
+ return _c('transition', {
+ attrs: {
+ "name": "el-zoom-in-top"
+ },
+ on: {
+ "before-enter": _vm.panelCreated,
+ "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",
+ class: _vm.popperClass,
+ style: ({
+ width: _vm.width + 'px'
+ })
+ }, [_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: {
- 'is-error': _vm.validateState === 'error',
- 'is-validating': _vm.validateState === 'validating',
- 'is-required': _vm.isRequired || _vm.required
+ 'has-seconds': _vm.showSeconds
}
- }, [(_vm.label || _vm.$slots.label) ? _c('label', {
- staticClass: "el-form-item__label",
- style: (_vm.labelStyle),
+ }, [_c('time-spinner', {
+ ref: "minSpinner",
attrs: {
- "for": _vm.prop
+ "show-seconds": _vm.showSeconds,
+ "hours": _vm.minHours,
+ "minutes": _vm.minMinutes,
+ "seconds": _vm.minSeconds
+ },
+ on: {
+ "change": _vm.handleMinChange,
+ "select-range": _vm.setMinSelectionRange
}
- }, [_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', {
+ })], 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
+ }
+ }, [_c('time-spinner', {
+ ref: "maxSpinner",
attrs: {
- "name": "el-zoom-in-top"
+ "show-seconds": _vm.showSeconds,
+ "hours": _vm.maxHours,
+ "minutes": _vm.maxMinutes,
+ "seconds": _vm.maxSeconds
+ },
+ on: {
+ "change": _vm.handleMaxChange,
+ "select-range": _vm.setMaxSelectionRange
}
- }, [(_vm.validateState === 'error' && _vm.showMessage && _vm.form.showMessage) ? _c('div', {
- staticClass: "el-form-item__error"
- }, [_vm._v(_vm._s(_vm.validateMessage))]) : _vm._e()])], 2)])
+ })], 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')))])])])])
},staticRenderFns: []}
/***/ },
-/* 217 */
+/* 187 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _tabs = __webpack_require__(218);
+ var _main = __webpack_require__(188);
- var _tabs2 = _interopRequireDefault(_tabs);
+ var _main2 = _interopRequireDefault(_main);
+
+ var _directive = __webpack_require__(191);
+
+ var _directive2 = _interopRequireDefault(_directive);
+
+ var _vue = __webpack_require__(133);
+
+ var _vue2 = _interopRequireDefault(_vue);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ _vue2.default.directive('popover', _directive2.default);
+
/* istanbul ignore next */
- _tabs2.default.install = function (Vue) {
- Vue.component(_tabs2.default.name, _tabs2.default);
+ _main2.default.install = function (Vue) {
+ Vue.directive('popover', _directive2.default);
+ Vue.component(_main2.default.name, _main2.default);
};
+ _main2.default.directive = _directive2.default;
- exports.default = _tabs2.default;
+ exports.default = _main2.default;
/***/ },
-/* 218 */
+/* 188 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(219),
+ __webpack_require__(189),
/* template */
- null,
+ __webpack_require__(190),
/* styles */
null,
/* scopeId */
@@ -50986,749 +50606,685 @@ module.exports =
/***/ },
-/* 219 */
+/* 189 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _tabNav = __webpack_require__(220);
+ var _vuePopper = __webpack_require__(24);
- var _tabNav2 = _interopRequireDefault(_tabNav);
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
+
+ var _dom = __webpack_require__(44);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
exports.default = {
- name: 'ElTabs',
+ name: 'ElPopover',
- components: {
- TabNav: _tabNav2.default
- },
+ mixins: [_vuePopper2.default],
props: {
- type: String,
- activeName: String,
- closable: Boolean,
- addable: Boolean,
- value: {},
- editable: Boolean
- },
-
- data: function data() {
- return {
- currentName: this.value || this.activeName,
- panes: []
- };
- },
-
-
- watch: {
- activeName: function activeName(value) {
- this.setCurrentName(value);
+ trigger: {
+ type: String,
+ default: 'click',
+ validator: function validator(value) {
+ return ['click', 'focus', 'hover', 'manual'].indexOf(value) > -1;
+ }
},
- value: function value(_value) {
- this.setCurrentName(_value);
+ openDelay: {
+ type: Number,
+ default: 0
},
- currentName: function currentName(value) {
- var _this = this;
+ title: String,
+ disabled: Boolean,
+ content: String,
+ reference: {},
+ popperClass: String,
+ width: {},
+ visibleArrow: {
+ default: true
+ },
+ transition: {
+ type: String,
+ default: 'fade-in-linear'
+ }
+ },
- if (this.$refs.nav) {
- this.$nextTick(function (_) {
- _this.$refs.nav.scrollToActiveTab();
- });
- }
+ watch: {
+ showPopper: function showPopper(newVal, oldVal) {
+ newVal ? this.$emit('show') : this.$emit('hide');
}
},
- methods: {
- 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) {
- this.currentName = value;
- this.$emit('input', value);
- },
- addPanes: function addPanes(item) {
- var index = this.$slots.default.filter(function (item) {
- return item.elm.nodeType === 1 && /\bel-tab-pane\b/.test(item.elm.className);
- }).indexOf(item.$vnode);
- this.panes.splice(index, 0, item);
- },
- removePanes: function removePanes(item) {
- var panes = this.panes;
- var index = panes.indexOf(item);
- if (index > -1) {
- panes.splice(index, 1);
+ mounted: function mounted() {
+ 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.trigger === 'click') {
+ (0, _dom.on)(reference, 'click', this.doToggle);
+ (0, _dom.on)(document, 'click', this.handleDocumentClick);
+ } else if (this.trigger === 'hover') {
+ (0, _dom.on)(reference, 'mouseenter', this.handleMouseEnter);
+ (0, _dom.on)(popper, 'mouseenter', this.handleMouseEnter);
+ (0, _dom.on)(reference, 'mouseleave', this.handleMouseLeave);
+ (0, _dom.on)(popper, 'mouseleave', this.handleMouseLeave);
+ } else if (this.trigger === 'focus') {
+ var found = false;
+
+ if ([].slice.call(reference.children).length) {
+ var children = reference.childNodes;
+ var len = children.length;
+ for (var i = 0; i < len; i++) {
+ if (children[i].nodeName === 'INPUT' || children[i].nodeName === 'TEXTAREA') {
+ (0, _dom.on)(children[i], 'focus', this.doShow);
+ (0, _dom.on)(children[i], 'blur', this.doClose);
+ found = true;
+ break;
+ }
+ }
+ }
+ if (found) return;
+ if (reference.nodeName === 'INPUT' || reference.nodeName === 'TEXTAREA') {
+ (0, _dom.on)(reference, 'focus', this.doShow);
+ (0, _dom.on)(reference, 'blur', this.doClose);
+ } else {
+ (0, _dom.on)(reference, 'mousedown', this.doShow);
+ (0, _dom.on)(reference, 'mouseup', this.doClose);
}
}
},
- render: function render(h) {
- 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;
- var newButton = editable || addable ? h(
- 'span',
- {
- 'class': 'el-tabs__new-tab',
- on: {
- 'click': handleTabAdd
- }
- },
- [h(
- 'i',
- { 'class': 'el-icon-plus' },
- []
- )]
- ) : null;
+ methods: {
+ doToggle: function doToggle() {
+ this.showPopper = !this.showPopper;
+ },
+ doShow: function doShow() {
+ this.showPopper = true;
+ },
+ doClose: function doClose() {
+ this.showPopper = false;
+ },
+ handleMouseEnter: function handleMouseEnter() {
+ var _this = this;
- var navData = {
- props: {
- currentName: currentName,
- onTabClick: handleTabClick,
- onTabRemove: handleTabRemove,
- editable: editable,
- type: type,
- panes: panes
- },
- ref: 'nav'
- };
+ clearTimeout(this._timer);
+ if (this.openDelay) {
+ this._timer = setTimeout(function () {
+ _this.showPopper = true;
+ }, this.openDelay);
+ } else {
+ this.showPopper = true;
+ }
+ },
+ handleMouseLeave: function handleMouseLeave() {
+ var _this2 = this;
- return h(
- 'div',
- { 'class': {
- 'el-tabs': true,
- 'el-tabs--card': type === 'card',
- 'el-tabs--border-card': type === 'border-card'
- } },
- [h(
- 'div',
- { 'class': 'el-tabs__header' },
- [newButton, h(
- 'tab-nav',
- navData,
- []
- )]
- ), h(
- 'div',
- { 'class': 'el-tabs__content' },
- [this.$slots.default]
- )]
- );
- },
- created: function created() {
- if (!this.currentName) {
- this.setCurrentName('0');
+ clearTimeout(this._timer);
+ this._timer = setTimeout(function () {
+ _this2.showPopper = false;
+ }, 200);
+ },
+ 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;
}
+ },
+
+ destroyed: function destroyed() {
+ var reference = this.reference;
+
+ (0, _dom.off)(reference, 'click', this.doToggle);
+ (0, _dom.off)(reference, 'mouseup', this.doClose);
+ (0, _dom.off)(reference, 'mousedown', this.doShow);
+ (0, _dom.off)(reference, 'focus', this.doShow);
+ (0, _dom.off)(reference, 'blur', this.doClose);
+ (0, _dom.off)(reference, 'mouseleave', this.handleMouseLeave);
+ (0, _dom.off)(reference, 'mouseenter', this.handleMouseEnter);
+ (0, _dom.off)(document, 'click', this.handleDocumentClick);
}
};
/***/ },
-/* 220 */
-/***/ function(module, exports, __webpack_require__) {
+/* 190 */
+/***/ function(module, exports) {
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(221),
- /* template */
- null,
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ module.exports={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-leave": _vm.doDestroy
+ }
+ }, [_c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (!_vm.disabled && _vm.showPopper),
+ expression: "!disabled && showPopper"
+ }],
+ ref: "popper",
+ staticClass: "el-popover",
+ class: [_vm.popperClass],
+ style: ({
+ width: _vm.width + 'px'
+ })
+ }, [(_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)
+ },staticRenderFns: []}
- module.exports = Component.exports
+/***/ },
+/* 191 */
+/***/ function(module, exports) {
+ "use strict";
+
+ exports.__esModule = true;
+ exports.default = {
+ bind: function bind(el, binding, vnode) {
+ vnode.context.$refs[binding.arg].$refs.reference = el;
+ }
+ };
/***/ },
-/* 221 */
+/* 192 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _tabBar = __webpack_require__(222);
-
- var _tabBar2 = _interopRequireDefault(_tabBar);
+ var _main = __webpack_require__(193);
- var _resizeEvent = __webpack_require__(110);
+ var _main2 = _interopRequireDefault(_main);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- function noop() {}
+ /* istanbul ignore next */
+ _main2.default.install = function (Vue) {
+ Vue.component(_main2.default.name, _main2.default);
+ };
- exports.default = {
- name: 'TabNav',
+ exports.default = _main2.default;
- components: {
- TabBar: _tabBar2.default
- },
+/***/ },
+/* 193 */
+/***/ function(module, exports, __webpack_require__) {
- props: {
- panes: Array,
- currentName: String,
- editable: Boolean,
- onTabClick: {
- type: Function,
- default: noop
- },
- onTabRemove: {
- type: Function,
- default: noop
- },
- type: String
- },
+ 'use strict';
- data: function data() {
- return {
- scrollable: false,
- navStyle: {
- transform: ''
- }
- };
- },
+ exports.__esModule = true;
+ var _vuePopper = __webpack_require__(24);
- methods: {
- scrollPrev: function scrollPrev() {
- var containerWidth = this.$refs.navScroll.offsetWidth;
- var currentOffset = this.getCurrentScrollOffset();
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
- if (!currentOffset) return;
+ var _debounce = __webpack_require__(69);
- var newOffset = currentOffset > containerWidth ? currentOffset - containerWidth : 0;
+ var _debounce2 = _interopRequireDefault(_debounce);
- this.setOffset(newOffset);
- },
- scrollNext: function scrollNext() {
- var navWidth = this.$refs.nav.offsetWidth;
- var containerWidth = this.$refs.navScroll.offsetWidth;
- var currentOffset = this.getCurrentScrollOffset();
+ var _vdom = __webpack_require__(194);
- if (navWidth - currentOffset <= containerWidth) return;
+ var _vue = __webpack_require__(133);
- var newOffset = navWidth - currentOffset > containerWidth * 2 ? currentOffset + containerWidth : navWidth - containerWidth;
+ var _vue2 = _interopRequireDefault(_vue);
- this.setOffset(newOffset);
- },
- scrollToActiveTab: function scrollToActiveTab() {
- if (!this.scrollable) return;
- var nav = this.$refs.nav;
- var activeTab = this.$el.querySelector('.is-active');
- var navScroll = this.$refs.navScroll;
- var activeTabBounding = activeTab.getBoundingClientRect();
- var navScrollBounding = navScroll.getBoundingClientRect();
- var navBounding = nav.getBoundingClientRect();
- var currentOffset = this.getCurrentScrollOffset();
- var newOffset = currentOffset;
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- if (activeTabBounding.left < navScrollBounding.left) {
- newOffset = currentOffset - (navScrollBounding.left - activeTabBounding.left);
- }
- if (activeTabBounding.right > navScrollBounding.right) {
- newOffset = currentOffset + activeTabBounding.right - navScrollBounding.right;
- }
- if (navBounding.right < navScrollBounding.right) {
- newOffset = nav.offsetWidth - navScrollBounding.width;
- }
- this.setOffset(Math.max(newOffset, 0));
- },
- getCurrentScrollOffset: function getCurrentScrollOffset() {
- var navStyle = this.navStyle;
+ exports.default = {
+ name: 'ElTooltip',
- return navStyle.transform ? Number(navStyle.transform.match(/translateX\(-(\d+(\.\d+)*)px\)/)[1]) : 0;
+ mixins: [_vuePopper2.default],
+
+ props: {
+ openDelay: {
+ type: Number,
+ default: 0
},
- setOffset: function setOffset(value) {
- this.navStyle.transform = 'translateX(-' + value + 'px)';
+ disabled: Boolean,
+ manual: Boolean,
+ effect: {
+ type: String,
+ default: 'dark'
},
- update: function update() {
- var navWidth = this.$refs.nav.offsetWidth;
- var containerWidth = this.$refs.navScroll.offsetWidth;
- var currentOffset = this.getCurrentScrollOffset();
-
- if (containerWidth < navWidth) {
- var _currentOffset = this.getCurrentScrollOffset();
- this.scrollable = this.scrollable || {};
- this.scrollable.prev = _currentOffset;
- this.scrollable.next = _currentOffset + containerWidth < navWidth;
- if (navWidth - _currentOffset < containerWidth) {
- this.setOffset(navWidth - containerWidth);
- }
- } else {
- this.scrollable = false;
- if (currentOffset > 0) {
- this.setOffset(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
}
},
- updated: function updated() {
- this.update();
- },
- render: function render(h) {
- var type = this.type,
- panes = this.panes,
- editable = this.editable,
- onTabClick = this.onTabClick,
- onTabRemove = this.onTabRemove,
- navStyle = this.navStyle,
- scrollable = this.scrollable,
- scrollNext = this.scrollNext,
- scrollPrev = this.scrollPrev;
-
-
- 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;
+ beforeCreate: function beforeCreate() {
+ var _this = this;
- var tabs = this._l(panes, function (pane, index) {
- var tabName = pane.name || pane.index || index;
- var closable = pane.isClosable || editable;
+ if (this.$isServer) return;
- pane.index = '' + index;
+ this.popperVM = new _vue2.default({
+ data: { node: '' },
+ render: function render(h) {
+ return this.node;
+ }
+ }).$mount();
- var btnClose = closable ? h(
- 'span',
- { 'class': 'el-icon-close', on: {
- 'click': function click(ev) {
- onTabRemove(pane, ev);
- }
- }
- },
- []
- ) : null;
+ this.debounceClose = (0, _debounce2.default)(200, function () {
+ return _this.handleClosePopper();
+ });
+ },
+ render: function render(h) {
+ var _this2 = this;
- var tabLabelContent = pane.$slots.label || pane.label;
- return h(
- 'div',
+ if (this.popperVM) {
+ this.popperVM.node = h(
+ 'transition',
{
- 'class': {
- 'el-tabs__item': true,
- 'is-active': pane.active,
- 'is-disabled': pane.disabled,
- 'is-closable': closable
+ attrs: {
+ name: this.transition
},
- ref: 'tabs',
- refInFor: true,
on: {
- 'click': function click(ev) {
- onTabClick(pane, tabName, ev);
- }
+ 'afterLeave': this.doDestroy
}
},
- [tabLabelContent, btnClose]
- );
- });
- return h(
- 'div',
- { 'class': ['el-tabs__nav-wrap', scrollable ? 'is-scrollable' : ''] },
- [scrollBtn, h(
- 'div',
- { 'class': ['el-tabs__nav-scroll'], ref: 'navScroll' },
[h(
'div',
- { 'class': 'el-tabs__nav', ref: 'nav', style: navStyle },
- [!type ? h(
- 'tab-bar',
- {
- attrs: { tabs: panes }
+ {
+ on: {
+ 'mouseleave': function mouseleave() {
+ _this2.setExpectedState(false);_this2.debounceClose();
+ },
+ 'mouseenter': function mouseenter() {
+ _this2.setExpectedState(true);
+ }
},
- []
- ) : null, tabs]
- )]
- )]
- );
- },
- mounted: function mounted() {
- (0, _resizeEvent.addResizeListener)(this.$el, this.update);
- },
- beforeDestroy: function beforeDestroy() {
- if (this.$el && this.update) (0, _resizeEvent.removeResizeListener)(this.$el, this.update);
- }
- };
-/***/ },
-/* 222 */
-/***/ function(module, exports, __webpack_require__) {
+ ref: 'popper',
+ directives: [{
+ name: 'show',
+ value: !this.disabled && this.showPopper
+ }],
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(223),
- /* template */
- __webpack_require__(224),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ 'class': ['el-tooltip__popper', 'is-' + this.effect, this.popperClass] },
+ [this.$slots.content || this.content]
+ )]
+ );
+ }
- module.exports = Component.exports
-
-
-/***/ },
-/* 223 */
-/***/ function(module, exports) {
-
- 'use strict';
+ if (!this.$slots.default || !this.$slots.default.length) return this.$slots.default;
- exports.__esModule = true;
- //
- //
- //
+ var vnode = (0, _vdom.getFirstComponentChild)(this.$slots.default);
+ if (!vnode) return vnode;
+ var data = vnode.data = vnode.data || {};
+ var on = vnode.data.on = vnode.data.on || {};
+ var nativeOn = vnode.data.nativeOn = vnode.data.nativeOn || {};
- exports.default = {
- name: 'TabBar',
+ on.mouseenter = this.addEventHandle(on.mouseenter, function () {
+ _this2.setExpectedState(true);_this2.handleShowPopper();
+ });
+ on.mouseleave = this.addEventHandle(on.mouseleave, function () {
+ _this2.setExpectedState(false);_this2.debounceClose();
+ });
+ nativeOn.mouseenter = this.addEventHandle(nativeOn.mouseenter, function () {
+ _this2.setExpectedState(true);_this2.handleShowPopper();
+ });
+ nativeOn.mouseleave = this.addEventHandle(nativeOn.mouseleave, function () {
+ _this2.setExpectedState(false);_this2.debounceClose();
+ });
+ data.staticClass = this.concatClass(data.staticClass, 'el-tooltip');
- props: {
- tabs: Array
+ return vnode;
+ },
+ mounted: function mounted() {
+ this.referenceElm = this.$el;
},
- computed: {
- barStyle: {
- cache: false,
- get: function get() {
- var _this = this;
-
- if (!this.$parent.$refs.tabs) return {};
- var style = {};
- var offset = 0;
- var tabWidth = 0;
-
- this.tabs.every(function (tab, index) {
- var $el = _this.$parent.$refs.tabs[index];
- if (!$el) {
- return false;
- }
-
- if (!tab.active) {
- offset += $el.clientWidth;
- return true;
- } else {
- tabWidth = $el.clientWidth;
- return false;
- }
- });
- var transform = 'translateX(' + offset + 'px)';
- style.width = tabWidth + 'px';
- style.transform = transform;
- style.msTransform = transform;
- style.webkitTransform = transform;
+ methods: {
+ addEventHandle: function addEventHandle(old, fn) {
+ return old ? Array.isArray(old) ? old.concat(fn) : [old, fn] : fn;
+ },
+ concatClass: function concatClass(a, b) {
+ if (a && a.indexOf(b) > -1) return a;
+ return a ? b ? a + ' ' + b : a : b || '';
+ },
+ handleShowPopper: function handleShowPopper() {
+ var _this3 = this;
- return style;
- }
+ if (!this.expectedState || this.manual) return;
+ clearTimeout(this.timeout);
+ this.timeout = setTimeout(function () {
+ _this3.showPopper = true;
+ }, this.openDelay);
+ },
+ handleClosePopper: function handleClosePopper() {
+ if (this.enterable && this.expectedState || this.manual) return;
+ clearTimeout(this.timeout);
+ this.showPopper = false;
+ },
+ setExpectedState: function setExpectedState(expectedState) {
+ this.expectedState = expectedState;
}
}
};
/***/ },
-/* 224 */
+/* 194 */
/***/ function(module, exports) {
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-tabs__active-bar",
- style: (_vm.barStyle)
- })
- },staticRenderFns: []}
+ module.exports = __webpack_require__(27);
/***/ },
-/* 225 */
+/* 195 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _tabPane = __webpack_require__(226);
+ var _main = __webpack_require__(196);
- var _tabPane2 = _interopRequireDefault(_tabPane);
+ var _main2 = _interopRequireDefault(_main);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- /* istanbul ignore next */
- _tabPane2.default.install = function (Vue) {
- Vue.component(_tabPane2.default.name, _tabPane2.default);
- };
-
- exports.default = _tabPane2.default;
+ exports.default = _main2.default;
/***/ },
-/* 226 */
+/* 196 */
/***/ function(module, exports, __webpack_require__) {
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(227),
- /* template */
- __webpack_require__(228),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ 'use strict';
- module.exports = Component.exports
+ exports.__esModule = true;
+ exports.MessageBox = undefined;
+ 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; };
-/***/ },
-/* 227 */
-/***/ function(module, exports) {
+ var _vue = __webpack_require__(133);
- 'use strict';
+ var _vue2 = _interopRequireDefault(_vue);
- exports.__esModule = true;
- //
- //
- //
- //
- //
+ var _main = __webpack_require__(197);
- exports.default = {
- name: 'ElTabPane',
+ var _main2 = _interopRequireDefault(_main);
- componentName: 'ElTabPane',
+ var _merge = __webpack_require__(64);
- props: {
- label: String,
- labelContent: Function,
- name: String,
- closable: Boolean,
- disabled: Boolean
- },
+ var _merge2 = _interopRequireDefault(_merge);
- data: function data() {
- return {
- index: null
- };
- },
+ var _vdom = __webpack_require__(194);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- computed: {
- isClosable: function isClosable() {
- return this.closable || this.$parent.closable;
- },
- active: function active() {
- return this.$parent.currentName === (this.name || this.index);
- }
- },
+ var defaults = {
+ title: undefined,
+ message: '',
+ type: '',
+ showInput: false,
+ showClose: true,
+ modalFade: true,
+ lockScroll: true,
+ closeOnClickModal: true,
+ closeOnPressEscape: true,
+ inputValue: null,
+ inputPlaceholder: '',
+ inputPattern: null,
+ inputValidator: null,
+ inputErrorMessage: '',
+ showConfirmButton: true,
+ showCancelButton: false,
+ confirmButtonPosition: 'right',
+ confirmButtonHighlight: false,
+ cancelButtonHighlight: false,
+ confirmButtonText: '',
+ cancelButtonText: '',
+ confirmButtonClass: '',
+ cancelButtonClass: '',
+ customClass: '',
+ beforeClose: null
+ };
- mounted: function mounted() {
- this.$parent.addPanes(this);
- },
- destroyed: function destroyed() {
- if (this.$el && this.$el.parentNode) {
- this.$el.parentNode.removeChild(this.$el);
- }
- this.$parent.removePanes(this);
- },
+ var MessageBoxConstructor = _vue2.default.extend(_main2.default);
+ var currentMsg = void 0,
+ instance = void 0;
+ var msgQueue = [];
- watch: {
- label: function label() {
- this.$parent.$forceUpdate();
+ var defaultCallback = function defaultCallback(action) {
+ if (currentMsg) {
+ var callback = currentMsg.callback;
+ if (typeof callback === 'function') {
+ if (instance.showInput) {
+ callback(instance.inputValue, action);
+ } else {
+ callback(action);
+ }
+ }
+ if (currentMsg.resolve) {
+ if (action === 'confirm') {
+ if (instance.showInput) {
+ currentMsg.resolve({ value: instance.inputValue, action: action });
+ } else {
+ currentMsg.resolve(action);
+ }
+ } else if (action === 'cancel' && currentMsg.reject) {
+ currentMsg.reject(action);
+ }
}
}
};
-/***/ },
-/* 228 */
-/***/ function(module, exports) {
-
- module.exports={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.active),
- expression: "active"
- }],
- staticClass: "el-tab-pane"
- }, [_vm._t("default")], 2)
- },staticRenderFns: []}
-
-/***/ },
-/* 229 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _tag = __webpack_require__(230);
-
- var _tag2 = _interopRequireDefault(_tag);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var initInstance = function initInstance() {
+ instance = new MessageBoxConstructor({
+ el: document.createElement('div')
+ });
- /* istanbul ignore next */
- _tag2.default.install = function (Vue) {
- Vue.component(_tag2.default.name, _tag2.default);
+ instance.callback = defaultCallback;
};
- exports.default = _tag2.default;
-
-/***/ },
-/* 230 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(231),
- /* template */
- __webpack_require__(232),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
+ var showNextMsg = function showNextMsg() {
+ if (!instance) {
+ initInstance();
+ }
+ instance.action = '';
-/***/ },
-/* 231 */
-/***/ function(module, exports) {
+ if (!instance.visible || instance.closeTimer) {
+ if (msgQueue.length > 0) {
+ (function () {
+ currentMsg = msgQueue.shift();
- 'use strict';
+ var options = currentMsg.options;
+ for (var prop in options) {
+ if (options.hasOwnProperty(prop)) {
+ instance[prop] = options[prop];
+ }
+ }
+ if (options.callback === undefined) {
+ instance.callback = defaultCallback;
+ }
- exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ var oldCb = instance.callback;
+ instance.callback = function (action, instance) {
+ oldCb(action, instance);
+ showNextMsg();
+ };
+ if ((0, _vdom.isVNode)(instance.message)) {
+ instance.$slots.default = [instance.message];
+ instance.message = null;
+ } else {
+ delete instance.$slots.default;
+ }
+ ['modal', 'showClose', 'closeOnClickModal', 'closeOnPressEscape'].forEach(function (prop) {
+ if (instance[prop] === undefined) {
+ instance[prop] = true;
+ }
+ });
+ document.body.appendChild(instance.$el);
- exports.default = {
- name: 'ElTag',
- props: {
- text: String,
- closable: Boolean,
- type: String,
- hit: Boolean,
- closeTransition: Boolean,
- color: String
- },
- methods: {
- handleClose: function handleClose(event) {
- this.$emit('close', event);
+ _vue2.default.nextTick(function () {
+ instance.visible = true;
+ });
+ })();
}
}
};
-/***/ },
-/* 232 */
-/***/ function(module, exports) {
-
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('transition', {
- attrs: {
- "name": _vm.closeTransition ? '' : 'el-zoom-in-center'
+ var MessageBox = function MessageBox(options, callback) {
+ if (_vue2.default.prototype.$isServer) return;
+ if (typeof options === 'string') {
+ options = {
+ message: options
+ };
+ if (arguments[1]) {
+ options.title = arguments[1];
}
- }, [_c('span', {
- staticClass: "el-tag",
- class: [_vm.type ? 'el-tag--' + _vm.type : '', {
- 'is-hit': _vm.hit
- }],
- style: ({
- backgroundColor: _vm.color
- })
- }, [_vm._t("default"), (_vm.closable) ? _c('i', {
- staticClass: "el-tag__close el-icon-close",
- on: {
- "click": _vm.handleClose
+ if (arguments[2]) {
+ options.type = arguments[2];
}
- }) : _vm._e()], 2)])
- },staticRenderFns: []}
+ } else if (options.callback && !callback) {
+ callback = options.callback;
+ }
-/***/ },
-/* 233 */
-/***/ function(module, exports, __webpack_require__) {
+ if (typeof Promise !== 'undefined') {
+ return new Promise(function (resolve, reject) {
+ // eslint-disable-line
+ msgQueue.push({
+ options: (0, _merge2.default)({}, defaults, MessageBox.defaults, options),
+ callback: callback,
+ resolve: resolve,
+ reject: reject
+ });
- 'use strict';
+ showNextMsg();
+ });
+ } else {
+ msgQueue.push({
+ options: (0, _merge2.default)({}, defaults, MessageBox.defaults, options),
+ callback: callback
+ });
- exports.__esModule = true;
+ showNextMsg();
+ }
+ };
- var _tree = __webpack_require__(234);
+ MessageBox.setDefaults = function (defaults) {
+ MessageBox.defaults = defaults;
+ };
- var _tree2 = _interopRequireDefault(_tree);
+ MessageBox.alert = function (message, title, options) {
+ if ((typeof title === 'undefined' ? 'undefined' : _typeof(title)) === 'object') {
+ options = title;
+ title = '';
+ } else if (title === undefined) {
+ title = '';
+ }
+ return MessageBox((0, _merge2.default)({
+ title: title,
+ message: message,
+ $type: 'alert',
+ closeOnPressEscape: false,
+ closeOnClickModal: false
+ }, options));
+ };
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ MessageBox.confirm = function (message, title, options) {
+ if ((typeof title === 'undefined' ? 'undefined' : _typeof(title)) === 'object') {
+ options = title;
+ title = '';
+ } else if (title === undefined) {
+ title = '';
+ }
+ return MessageBox((0, _merge2.default)({
+ title: title,
+ message: message,
+ $type: 'confirm',
+ showCancelButton: true
+ }, options));
+ };
- /* istanbul ignore next */
- _tree2.default.install = function (Vue) {
- Vue.component(_tree2.default.name, _tree2.default);
+ MessageBox.prompt = function (message, title, options) {
+ if ((typeof title === 'undefined' ? 'undefined' : _typeof(title)) === 'object') {
+ options = title;
+ title = '';
+ } else if (title === undefined) {
+ title = '';
+ }
+ return MessageBox((0, _merge2.default)({
+ title: title,
+ message: message,
+ showCancelButton: true,
+ showInput: true,
+ $type: 'prompt'
+ }, options));
};
- exports.default = _tree2.default;
+ MessageBox.close = function () {
+ instance.visible = false;
+ msgQueue = [];
+ currentMsg = null;
+ };
+
+ exports.default = MessageBox;
+ exports.MessageBox = MessageBox;
/***/ },
-/* 234 */
+/* 197 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(235),
+ __webpack_require__(198),
/* template */
- __webpack_require__(242),
+ __webpack_require__(199),
/* styles */
null,
/* scopeId */
@@ -51741,1040 +51297,1285 @@ module.exports =
/***/ },
-/* 235 */
+/* 198 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _treeStore = __webpack_require__(236);
+ var _popup = __webpack_require__(14);
- var _treeStore2 = _interopRequireDefault(_treeStore);
+ var _popup2 = _interopRequireDefault(_popup);
- var _locale = __webpack_require__(111);
+ var _locale = __webpack_require__(10);
- var _emitter = __webpack_require__(15);
+ var _locale2 = _interopRequireDefault(_locale);
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _input = __webpack_require__(20);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _input2 = _interopRequireDefault(_input);
- exports.default = {
- name: 'ElTree',
+ var _button = __webpack_require__(31);
- mixins: [_emitter2.default],
+ var _button2 = _interopRequireDefault(_button);
- components: {
- ElTreeNode: __webpack_require__(239)
- },
+ var _dom = __webpack_require__(44);
- data: function data() {
- return {
- store: null,
- root: null,
- currentNode: null
- };
- },
+ var _locale3 = __webpack_require__(111);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+ var typeMap = {
+ success: 'circle-check',
+ info: 'information',
+ warning: 'warning',
+ error: 'circle-cross'
+ };
+ exports.default = {
+ mixins: [_popup2.default, _locale2.default],
props: {
- data: {
- type: Array
- },
- emptyText: {
- type: String,
- default: function _default() {
- return (0, _locale.t)('el.tree.emptyText');
- }
- },
- nodeKey: String,
- checkStrictly: Boolean,
- defaultExpandAll: Boolean,
- expandOnClickNode: {
- type: Boolean,
+ modal: {
default: true
},
- autoExpandParent: {
- type: Boolean,
+ lockScroll: {
default: true
},
- defaultCheckedKeys: Array,
- defaultExpandedKeys: Array,
- renderContent: Function,
- showCheckbox: {
+ showClose: {
type: Boolean,
- default: false
- },
- props: {
- default: function _default() {
- return {
- children: 'children',
- label: 'label',
- icon: 'icon',
- disabled: 'disabled'
- };
- }
+ default: true
},
- lazy: {
- type: Boolean,
- default: false
+ closeOnClickModal: {
+ default: true
},
- highlightCurrent: Boolean,
- currentNodeKey: [String, Number],
- load: Function,
- filterNodeMethod: Function,
- accordion: Boolean,
- indent: {
- type: Number,
- default: 16
+ closeOnPressEscape: {
+ default: true
}
},
- computed: {
- children: {
- set: function set(value) {
- this.data = value;
- },
- get: function get() {
- return this.data;
- }
- }
+ components: {
+ ElInput: _input2.default,
+ ElButton: _button2.default
},
- watch: {
- defaultCheckedKeys: function defaultCheckedKeys(newVal) {
- this.store.defaultCheckedKeys = newVal;
- this.store.setDefaultCheckedKey(newVal);
- },
- defaultExpandedKeys: function defaultExpandedKeys(newVal) {
- this.store.defaultExpandedKeys = newVal;
- this.store.setDefaultExpandedKeys(newVal);
+ computed: {
+ typeClass: function typeClass() {
+ return this.type && typeMap[this.type] ? 'el-icon-' + typeMap[this.type] : '';
},
- currentNodeKey: function currentNodeKey(newVal) {
- this.store.setCurrentNodeKey(newVal);
- this.store.currentNodeKey = newVal;
+ confirmButtonClasses: function confirmButtonClasses() {
+ return 'el-button--primary ' + this.confirmButtonClass;
},
- data: function data(newVal) {
- this.store.setData(newVal);
+ cancelButtonClasses: function cancelButtonClasses() {
+ return '' + this.cancelButtonClass;
}
},
methods: {
- filter: function filter(value) {
- if (!this.filterNodeMethod) throw new Error('[Tree] filterNodeMethod is required when filter');
- this.store.filter(value);
+ getSafeClose: function getSafeClose() {
+ var _this = this;
+
+ var currentId = this.uid;
+ return function () {
+ _this.$nextTick(function () {
+ if (currentId === _this.uid) _this.doClose();
+ });
+ };
},
- getNodeKey: function getNodeKey(node, index) {
- var nodeKey = this.nodeKey;
- if (nodeKey && node) {
- return node.data[nodeKey];
+ doClose: function doClose() {
+ var _this2 = this;
+
+ if (!this.visible) return;
+ this.visible = false;
+ this._closing = true;
+
+ this.onClose && this.onClose();
+
+ if (this.lockScroll) {
+ setTimeout(function () {
+ if (_this2.modal && _this2.bodyOverflow !== 'hidden') {
+ document.body.style.overflow = _this2.bodyOverflow;
+ document.body.style.paddingRight = _this2.bodyPaddingRight;
+ }
+ _this2.bodyOverflow = null;
+ _this2.bodyPaddingRight = null;
+ }, 200);
}
- return index;
- },
- getCheckedNodes: function getCheckedNodes(leafOnly) {
- return this.store.getCheckedNodes(leafOnly);
- },
- getCheckedKeys: function getCheckedKeys(leafOnly) {
- return this.store.getCheckedKeys(leafOnly);
- },
- setCheckedNodes: function setCheckedNodes(nodes, leafOnly) {
- if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCheckedNodes');
- this.store.setCheckedNodes(nodes, leafOnly);
+ this.opened = false;
+
+ if (!this.transition) {
+ this.doAfterClose();
+ }
+ if (this.action) this.callback(this.action, this);
},
- setCheckedKeys: function setCheckedKeys(keys, leafOnly) {
- if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCheckedNodes');
- this.store.setCheckedKeys(keys, leafOnly);
+ handleWrapperClick: function handleWrapperClick() {
+ if (this.closeOnClickModal) {
+ this.handleAction('cancel');
+ }
},
- setChecked: function setChecked(data, checked, deep) {
- this.store.setChecked(data, checked, deep);
+ 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();
+ }
},
- handleNodeExpand: function handleNodeExpand(nodeData, node, instance) {
- this.broadcast('ElTreeNode', 'tree-node-expand', node);
- this.$emit('node-expand', nodeData, node, instance);
+ validate: function validate() {
+ if (this.$type === 'prompt') {
+ var inputPattern = this.inputPattern;
+ if (inputPattern && !inputPattern.test(this.inputValue || '')) {
+ this.editorErrorMessage = this.inputErrorMessage || (0, _locale3.t)('el.messagebox.error');
+ (0, _dom.addClass)(this.$refs.input.$el.querySelector('input'), 'invalid');
+ return false;
+ }
+ var inputValidator = this.inputValidator;
+ if (typeof inputValidator === 'function') {
+ var validateResult = inputValidator(this.inputValue);
+ if (validateResult === false) {
+ this.editorErrorMessage = this.inputErrorMessage || (0, _locale3.t)('el.messagebox.error');
+ (0, _dom.addClass)(this.$refs.input.$el.querySelector('input'), 'invalid');
+ return false;
+ }
+ if (typeof validateResult === 'string') {
+ this.editorErrorMessage = validateResult;
+ return false;
+ }
+ }
+ }
+ this.editorErrorMessage = '';
+ (0, _dom.removeClass)(this.$refs.input.$el.querySelector('input'), 'invalid');
+ return true;
}
},
- created: function created() {
- this.isTree = true;
+ watch: {
+ inputValue: {
+ immediate: true,
+ handler: function handler(val) {
+ var _this3 = this;
- this.store = new _treeStore2.default({
- key: this.nodeKey,
- data: this.data,
- lazy: this.lazy,
- props: this.props,
- load: this.load,
- currentNodeKey: this.currentNodeKey,
- checkStrictly: this.checkStrictly,
- defaultCheckedKeys: this.defaultCheckedKeys,
- defaultExpandedKeys: this.defaultExpandedKeys,
- autoExpandParent: this.autoExpandParent,
- defaultExpandAll: this.defaultExpandAll,
- filterNodeMethod: this.filterNodeMethod
- });
+ this.$nextTick(function (_) {
+ if (_this3.$type === 'prompt' && val !== null) {
+ _this3.validate();
+ }
+ });
+ }
+ },
- this.root = this.store.root;
+ 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();
+ });
+ }
+ if (this.$type !== 'prompt') return;
+ if (val) {
+ setTimeout(function () {
+ if (_this4.$refs.input && _this4.$refs.input.$el) {
+ _this4.$refs.input.$el.querySelector('input').focus();
+ }
+ }, 500);
+ } else {
+ this.editorErrorMessage = '';
+ (0, _dom.removeClass)(this.$refs.input.$el.querySelector('input'), 'invalid');
+ }
+ }
+ },
+
+ data: function data() {
+ return {
+ uid: 1,
+ title: undefined,
+ message: '',
+ type: '',
+ customClass: '',
+ showInput: false,
+ inputValue: null,
+ inputPlaceholder: '',
+ inputPattern: null,
+ inputValidator: null,
+ inputErrorMessage: '',
+ showConfirmButton: true,
+ showCancelButton: false,
+ action: '',
+ confirmButtonText: '',
+ cancelButtonText: '',
+ confirmButtonLoading: false,
+ cancelButtonLoading: false,
+ confirmButtonClass: '',
+ confirmButtonDisabled: false,
+ cancelButtonClass: '',
+ editorErrorMessage: null,
+ callback: null
+ };
}
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ };
/***/ },
-/* 236 */
+/* 199 */
+/***/ function(module, exports) {
+
+ module.exports={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"
+ },
+ on: {
+ "click": function($event) {
+ if ($event.target !== $event.currentTarget) { return null; }
+ _vm.handleWrapperClick($event)
+ }
+ }
+ }, [_c('div', {
+ staticClass: "el-message-box",
+ class: _vm.customClass
+ }, [(_vm.title !== undefined) ? _c('div', {
+ staticClass: "el-message-box__header"
+ }, [_c('div', {
+ staticClass: "el-message-box__title"
+ }, [_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('cancel')
+ }
+ }
+ }, [_c('i', {
+ staticClass: "el-message-box__close el-icon-close"
+ })]) : _vm._e()]) : _vm._e(), (_vm.message !== '') ? _c('div', {
+ staticClass: "el-message-box__content"
+ }, [_c('div', {
+ staticClass: "el-message-box__status",
+ class: [_vm.typeClass]
+ }), _c('div', {
+ staticClass: "el-message-box__message",
+ style: ({
+ 'margin-left': _vm.typeClass ? '50px' : '0'
+ })
+ }, [_vm._t("default", [_c('p', [_vm._v(_vm._s(_vm.message))])])], 2), _c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.showInput),
+ expression: "showInput"
+ }],
+ staticClass: "el-message-box__input"
+ }, [_c('el-input', {
+ ref: "input",
+ attrs: {
+ "placeholder": _vm.inputPlaceholder
+ },
+ nativeOn: {
+ "keyup": function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
+ _vm.handleAction('confirm')
+ }
+ },
+ 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)]) : _vm._e(), _c('div', {
+ staticClass: "el-message-box__btns"
+ }, [_c('el-button', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.showCancelButton),
+ expression: "showCancelButton"
+ }],
+ class: [_vm.cancelButtonClasses],
+ attrs: {
+ "loading": _vm.cancelButtonLoading
+ },
+ nativeOn: {
+ "click": function($event) {
+ _vm.handleAction('cancel')
+ }
+ }
+ }, [_vm._v("\n " + _vm._s(_vm.cancelButtonText || _vm.t('el.messagebox.cancel')) + "\n ")]), _c('el-button', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.showConfirmButton),
+ expression: "showConfirmButton"
+ }],
+ ref: "confirm",
+ class: [_vm.confirmButtonClasses],
+ attrs: {
+ "loading": _vm.confirmButtonLoading
+ },
+ nativeOn: {
+ "click": function($event) {
+ _vm.handleAction('confirm')
+ }
+ }
+ }, [_vm._v("\n " + _vm._s(_vm.confirmButtonText || _vm.t('el.messagebox.confirm')) + "\n ")])], 1)])])])
+ },staticRenderFns: []}
+
+/***/ },
+/* 200 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- 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; };
-
- var _node = __webpack_require__(237);
-
- var _node2 = _interopRequireDefault(_node);
+ var _breadcrumb = __webpack_require__(201);
- var _util = __webpack_require__(238);
+ var _breadcrumb2 = _interopRequireDefault(_breadcrumb);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+ /* istanbul ignore next */
+ _breadcrumb2.default.install = function (Vue) {
+ Vue.component(_breadcrumb2.default.name, _breadcrumb2.default);
+ };
- var TreeStore = function () {
- function TreeStore(options) {
- var _this = this;
+ exports.default = _breadcrumb2.default;
- _classCallCheck(this, TreeStore);
+/***/ },
+/* 201 */
+/***/ function(module, exports, __webpack_require__) {
- this.currentNode = null;
- this.currentNodeKey = null;
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(202),
+ /* template */
+ __webpack_require__(203),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- for (var option in options) {
- if (options.hasOwnProperty(option)) {
- this[option] = options[option];
- }
- }
+ module.exports = Component.exports
- this.nodesMap = {};
- this.root = new _node2.default({
- data: this.data,
- store: this
- });
+/***/ },
+/* 202 */
+/***/ function(module, exports) {
- if (this.lazy && this.load) {
- var loadFn = this.load;
- loadFn(this.root, function (data) {
- _this.root.doCreateChildren(data);
- _this._initDefaultCheckedNodes();
- });
- } else {
- this._initDefaultCheckedNodes();
+ 'use strict';
+
+ exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+
+ exports.default = {
+ name: 'ElBreadcrumb',
+
+ props: {
+ separator: {
+ type: String,
+ default: '/'
}
}
+ };
- TreeStore.prototype.filter = function filter(value) {
- var filterNodeMethod = this.filterNodeMethod;
- var traverse = function traverse(node) {
- var childNodes = node.root ? node.root.childNodes : node.childNodes;
+/***/ },
+/* 203 */
+/***/ function(module, exports) {
- childNodes.forEach(function (child) {
- child.visible = filterNodeMethod.call(child, value, child.data, child);
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-breadcrumb"
+ }, [_vm._t("default")], 2)
+ },staticRenderFns: []}
- traverse(child);
- });
+/***/ },
+/* 204 */
+/***/ function(module, exports, __webpack_require__) {
- if (!node.visible && childNodes.length) {
- var allHidden = true;
+ 'use strict';
- childNodes.forEach(function (child) {
- if (child.visible) allHidden = false;
- });
+ exports.__esModule = true;
- if (node.root) {
- node.root.visible = allHidden === false;
- } else {
- node.visible = allHidden === false;
- }
- }
+ var _breadcrumbItem = __webpack_require__(205);
- if (node.visible && !node.isLeaf) node.expand();
- };
+ var _breadcrumbItem2 = _interopRequireDefault(_breadcrumbItem);
- traverse(this);
- };
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- TreeStore.prototype.setData = function setData(newVal) {
- var instanceChanged = newVal !== this.root.data;
- this.root.setData(newVal);
- if (instanceChanged) {
- this._initDefaultCheckedNodes();
- }
- };
+ /* istanbul ignore next */
+ _breadcrumbItem2.default.install = function (Vue) {
+ Vue.component(_breadcrumbItem2.default.name, _breadcrumbItem2.default);
+ };
- TreeStore.prototype.getNode = function getNode(data) {
- var key = (typeof data === 'undefined' ? 'undefined' : _typeof(data)) !== 'object' ? data : (0, _util.getNodeKey)(this.key, data);
- return this.nodesMap[key];
- };
+ exports.default = _breadcrumbItem2.default;
- TreeStore.prototype.insertBefore = function insertBefore(data, refData) {
- var refNode = this.getNode(refData);
- refNode.parent.insertBefore({ data: data }, refNode);
- };
+/***/ },
+/* 205 */
+/***/ function(module, exports, __webpack_require__) {
- TreeStore.prototype.insertAfter = function insertAfter(data, refData) {
- var refNode = this.getNode(refData);
- refNode.parent.insertAfter({ data: data }, refNode);
- };
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(206),
+ /* template */
+ __webpack_require__(207),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- TreeStore.prototype.remove = function remove(data) {
- var node = this.getNode(data);
- if (node) {
- node.parent.removeChild(node);
- }
- };
+ module.exports = Component.exports
- TreeStore.prototype.append = function append(data, parentData) {
- var parentNode = parentData ? this.getNode(parentData) : this.root;
- if (parentNode) {
- parentNode.insertChild({ data: data });
- }
- };
+/***/ },
+/* 206 */
+/***/ function(module, exports) {
- TreeStore.prototype._initDefaultCheckedNodes = function _initDefaultCheckedNodes() {
- var _this2 = this;
+ 'use strict';
- var defaultCheckedKeys = this.defaultCheckedKeys || [];
- var nodesMap = this.nodesMap;
+ exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
- defaultCheckedKeys.forEach(function (checkedKey) {
- var node = nodesMap[checkedKey];
+ exports.default = {
+ name: 'ElBreadcrumbItem',
+ props: {
+ to: {},
+ replace: Boolean
+ },
+ data: function data() {
+ return {
+ separator: ''
+ };
+ },
+ mounted: function mounted() {
+ var _this = this;
- if (node) {
- node.setChecked(true, !_this2.checkStrictly);
- }
- });
- };
+ this.separator = this.$parent.separator;
+ var self = this;
+ if (this.to) {
+ var link = this.$refs.link;
+ link.addEventListener('click', function (_) {
+ var to = _this.to;
+ self.replace ? self.$router.replace(to) : self.$router.push(to);
+ });
+ }
+ }
+ };
- TreeStore.prototype._initDefaultCheckedNode = function _initDefaultCheckedNode(node) {
- var defaultCheckedKeys = this.defaultCheckedKeys || [];
+/***/ },
+/* 207 */
+/***/ function(module, exports) {
- if (defaultCheckedKeys.indexOf(node.key) !== -1) {
- node.setChecked(true, !this.checkStrictly);
- }
- };
+ module.exports={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",
+ staticClass: "el-breadcrumb__item__inner"
+ }, [_vm._t("default")], 2), _c('span', {
+ staticClass: "el-breadcrumb__separator"
+ }, [_vm._v(_vm._s(_vm.separator))])])
+ },staticRenderFns: []}
- TreeStore.prototype.setDefaultCheckedKey = function setDefaultCheckedKey(newVal) {
- if (newVal !== this.defaultCheckedKeys) {
- this.defaultCheckedKeys = newVal;
- this._initDefaultCheckedNodes();
- }
- };
+/***/ },
+/* 208 */
+/***/ function(module, exports, __webpack_require__) {
- TreeStore.prototype.registerNode = function registerNode(node) {
- var key = this.key;
- if (!key || !node || !node.data) return;
+ 'use strict';
- var nodeKey = node.key;
- if (nodeKey !== undefined) this.nodesMap[node.key] = node;
- };
+ exports.__esModule = true;
- TreeStore.prototype.deregisterNode = function deregisterNode(node) {
- var key = this.key;
- if (!key || !node || !node.data) return;
+ var _form = __webpack_require__(209);
- delete this.nodesMap[node.key];
- };
+ var _form2 = _interopRequireDefault(_form);
- TreeStore.prototype.getCheckedNodes = function getCheckedNodes() {
- var leafOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var checkedNodes = [];
- var traverse = function traverse(node) {
- var childNodes = node.root ? node.root.childNodes : node.childNodes;
+ /* istanbul ignore next */
+ _form2.default.install = function (Vue) {
+ Vue.component(_form2.default.name, _form2.default);
+ };
- childNodes.forEach(function (child) {
- if (!leafOnly && child.checked || leafOnly && child.isLeaf && child.checked) {
- checkedNodes.push(child.data);
- }
+ exports.default = _form2.default;
- traverse(child);
- });
- };
+/***/ },
+/* 209 */
+/***/ function(module, exports, __webpack_require__) {
- traverse(this);
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(210),
+ /* template */
+ __webpack_require__(211),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- return checkedNodes;
- };
+ module.exports = Component.exports
- TreeStore.prototype.getCheckedKeys = function getCheckedKeys() {
- var leafOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- var key = this.key;
- var allNodes = this._getAllNodes();
- var keys = [];
- allNodes.forEach(function (node) {
- if (!leafOnly || leafOnly && node.isLeaf) {
- if (node.checked) {
- keys.push((node.data || {})[key]);
- }
- }
- });
- return keys;
- };
+/***/ },
+/* 210 */
+/***/ function(module, exports, __webpack_require__) {
- TreeStore.prototype._getAllNodes = function _getAllNodes() {
- var allNodes = [];
- var nodesMap = this.nodesMap;
- for (var nodeKey in nodesMap) {
- if (nodesMap.hasOwnProperty(nodeKey)) {
- allNodes.push(nodesMap[nodeKey]);
- }
- }
+ 'use strict';
- return allNodes;
- };
+ exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- TreeStore.prototype._setCheckedKeys = function _setCheckedKeys(key) {
- var leafOnly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
- var checkedKeys = arguments[2];
+ exports.default = {
+ name: 'ElForm',
- 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);
+ componentName: 'ElForm',
+
+ props: {
+ model: Object,
+ rules: Object,
+ labelPosition: String,
+ labelWidth: String,
+ labelSuffix: {
+ type: String,
+ default: ''
+ },
+ inline: Boolean,
+ showMessage: {
+ type: Boolean,
+ default: true
+ }
+ },
+ watch: {
+ rules: function rules() {
+ this.validate();
+ }
+ },
+ data: function data() {
+ return {
+ fields: []
+ };
+ },
+ created: function created() {
+ var _this = this;
+
+ this.$on('el.form.addField', function (field) {
+ if (field) {
+ _this.fields.push(field);
+ }
});
- 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;
+ /* istanbul ignore next */
+ this.$on('el.form.removeField', function (field) {
+ if (field.prop) {
+ _this.fields.splice(_this.fields.indexOf(field), 1);
}
+ });
+ },
- var parent = node.parent;
- while (parent && parent.level > 0) {
- cache[parent.data[key]] = true;
- parent = parent.parent;
+ methods: {
+ resetFields: function resetFields() {
+ if (!this.model) {
+ ("production") !== 'production' && console.warn('[Element Warn][Form]model is required for resetFields to work.');
+ return;
}
+ this.fields.forEach(function (field) {
+ field.resetField();
+ });
+ },
+ validate: function validate(callback) {
+ var _this2 = this;
- if (node.isLeaf || this.checkStrictly) {
- node.setChecked(true, false);
- continue;
+ if (!this.model) {
+ console.warn('[Element Warn][Form]model is required for validate to work!');
+ return;
+ };
+ var valid = true;
+ var count = 0;
+ // 如果需要验证的fields为空,调用验证时立刻返回callback
+ if (this.fields.length === 0 && callback) {
+ callback(true);
}
- 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);
- })();
+ this.fields.forEach(function (field, index) {
+ field.validate('', function (errors) {
+ if (errors) {
+ valid = false;
+ }
+ if (typeof callback === 'function' && ++count === _this2.fields.length) {
+ callback(valid);
+ }
+ });
+ });
+ },
+ validateField: function validateField(prop, cb) {
+ var field = this.fields.filter(function (field) {
+ return field.prop === prop;
+ })[0];
+ if (!field) {
+ throw new Error('must call validateField with valid prop string!');
}
- }
- };
- 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;
- });
+ field.validate('', cb);
+ }
+ }
+ };
- this._setCheckedKeys(key, leafOnly, checkedKeys);
- };
+/***/ },
+/* 211 */
+/***/ function(module, exports) {
- TreeStore.prototype.setCheckedKeys = function setCheckedKeys(keys) {
- var leafOnly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
+ module.exports={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)
+ },staticRenderFns: []}
- this.defaultCheckedKeys = keys;
- var key = this.key;
- var checkedKeys = {};
- keys.forEach(function (key) {
- checkedKeys[key] = true;
- });
+/***/ },
+/* 212 */
+/***/ function(module, exports, __webpack_require__) {
- this._setCheckedKeys(key, leafOnly, checkedKeys);
- };
+ 'use strict';
- TreeStore.prototype.setDefaultExpandedKeys = function setDefaultExpandedKeys(keys) {
- var _this3 = this;
+ exports.__esModule = true;
- keys = keys || [];
- this.defaultExpandedKeys = keys;
+ var _formItem = __webpack_require__(213);
- keys.forEach(function (key) {
- var node = _this3.getNode(key);
- if (node) node.expand(null, _this3.autoExpandParent);
- });
- };
+ var _formItem2 = _interopRequireDefault(_formItem);
- TreeStore.prototype.setChecked = function setChecked(data, checked, deep) {
- var node = this.getNode(data);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- if (node) {
- node.setChecked(!!checked, deep);
- }
- };
+ /* istanbul ignore next */
+ _formItem2.default.install = function (Vue) {
+ Vue.component(_formItem2.default.name, _formItem2.default);
+ };
- TreeStore.prototype.getCurrentNode = function getCurrentNode() {
- return this.currentNode;
- };
+ exports.default = _formItem2.default;
- TreeStore.prototype.setCurrentNode = function setCurrentNode(node) {
- this.currentNode = node;
- };
+/***/ },
+/* 213 */
+/***/ function(module, exports, __webpack_require__) {
- TreeStore.prototype.setCurrentNodeKey = function setCurrentNodeKey(key) {
- var node = this.getNode(key);
- if (node) {
- this.currentNode = node;
- }
- };
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(214),
+ /* template */
+ __webpack_require__(216),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- return TreeStore;
- }();
+ module.exports = Component.exports
- exports.default = TreeStore;
- ;
/***/ },
-/* 237 */
+/* 214 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- exports.getChildState = undefined;
- 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; }; }();
+ var _asyncValidator = __webpack_require__(215);
- var _merge = __webpack_require__(64);
+ var _asyncValidator2 = _interopRequireDefault(_asyncValidator);
- var _merge2 = _interopRequireDefault(_merge);
+ var _emitter = __webpack_require__(15);
- var _util = __webpack_require__(238);
+ var _emitter2 = _interopRequireDefault(_emitter);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var getChildState = exports.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;
+ function noop() {}
+
+ function getPropByPath(obj, path) {
+ var tempObj = obj;
+ path = path.replace(/\[(\w+)\]/g, '.$1');
+ path = path.replace(/^\./, '');
+
+ var keyArr = path.split('.');
+ var i = 0;
+
+ for (var len = keyArr.length; i < len - 1; ++i) {
+ var key = keyArr[i];
+ if (key in tempObj) {
+ tempObj = tempObj[key];
+ } else {
+ throw new Error('please transfer a valid prop path to form item!');
}
}
+ return {
+ o: tempObj,
+ k: keyArr[i],
+ v: tempObj[keyArr[i]]
+ };
+ }
- return { all: all, none: none, allWithoutDisable: allWithoutDisable, half: !all && !none };
- };
+ exports.default = {
+ name: 'ElFormItem',
- var reInitChecked = function reInitChecked(node) {
- var _getChildState = getChildState(node.childNodes),
- all = _getChildState.all,
- none = _getChildState.none,
- half = _getChildState.half;
+ componentName: 'ElFormItem',
- 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;
- }
+ mixins: [_emitter2.default],
- var parent = node.parent;
- if (!parent || parent.level === 0) return;
+ props: {
+ label: String,
+ labelWidth: String,
+ prop: String,
+ required: Boolean,
+ rules: [Object, Array],
+ error: String,
+ validateStatus: String,
+ showMessage: {
+ type: Boolean,
+ default: true
+ }
+ },
+ watch: {
+ error: function error(value) {
+ this.validateMessage = value;
+ this.validateState = value ? 'error' : '';
+ },
+ validateStatus: function validateStatus(value) {
+ this.validateState = value;
+ }
+ },
+ computed: {
+ 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) {
+ 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;
+ },
- if (!node.store.checkStrictly) {
- reInitChecked(parent);
- }
- };
+ fieldValue: {
+ cache: false,
+ get: function get() {
+ var model = this.form.model;
+ if (!model || !this.prop) {
+ return;
+ }
- var initLazyLoadChild = function initLazyLoadChild(node) {
- var childNodes = node.childNodes;
- if (node.checked) {
- for (var i = 0, j = childNodes.length; i < j; i++) {
- var child = childNodes[i];
- if (!child.disabled) {
- child.checked = true;
+ var path = this.prop;
+ if (path.indexOf(':') !== -1) {
+ path = path.replace(/:/, '.');
+ }
+
+ return getPropByPath(model, path).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;
}
- }
+ },
+ data: function data() {
+ return {
+ validateState: '',
+ validateMessage: '',
+ validateDisabled: false,
+ validator: {},
+ isNested: false
+ };
+ },
- var parent = node.parent;
- if (!parent || parent.level === 0) return;
- reInitChecked(parent);
- };
+ methods: {
+ validate: function validate(trigger) {
+ var _this = this;
- var getPropertyFromData = function getPropertyFromData(node, prop) {
- var props = node.store.props;
- var data = node.data || {};
- var config = props[prop];
+ var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : noop;
- if (typeof config === 'function') {
- return config(data, node);
- } else if (typeof config === 'string') {
- return data[config];
- } else if (typeof config === 'undefined') {
- return '';
- }
- };
+ var rules = this.getFilteredRule(trigger);
+ if (!rules || rules.length === 0) {
+ callback();
+ return true;
+ }
- var nodeIdSeed = 0;
+ this.validateState = 'validating';
- var Node = function () {
- function Node(options) {
- _classCallCheck(this, Node);
+ var descriptor = {};
+ descriptor[this.prop] = rules;
- this.id = nodeIdSeed++;
- this.text = null;
- this.checked = false;
- this.indeterminate = false;
- this.data = null;
- this.expanded = false;
- this.parent = null;
- this.visible = true;
+ var validator = new _asyncValidator2.default(descriptor);
+ var model = {};
- for (var name in options) {
- if (options.hasOwnProperty(name)) {
- this[name] = options[name];
- }
- }
+ model[this.prop] = this.fieldValue;
- // internal
- this.level = 0;
- this.loaded = false;
- this.childNodes = [];
- this.loading = false;
+ validator.validate(model, { firstFields: true }, function (errors, fields) {
+ _this.validateState = !errors ? 'success' : 'error';
+ _this.validateMessage = errors ? errors[0].message : '';
- if (this.parent) {
- this.level = this.parent.level + 1;
- }
+ callback(_this.validateMessage);
+ });
+ },
+ resetField: function resetField() {
+ this.validateState = '';
+ this.validateMessage = '';
- var store = this.store;
- if (!store) {
- throw new Error('[Node]store is required!');
- }
- store.registerNode(this);
+ var model = this.form.model;
+ var value = this.fieldValue;
+ var path = this.prop;
+ if (path.indexOf(':') !== -1) {
+ path = path.replace(/:/, '.');
+ }
- var props = store.props;
- if (props && typeof props.isLeaf !== 'undefined') {
- var isLeaf = getPropertyFromData(this, 'isLeaf');
- if (typeof isLeaf === 'boolean') {
- this.isLeafByUser = isLeaf;
+ var prop = getPropByPath(model, path);
+
+ if (Array.isArray(value)) {
+ this.validateDisabled = true;
+ prop.o[prop.k] = [].concat(this.initialValue);
+ } else {
+ this.validateDisabled = true;
+ prop.o[prop.k] = this.initialValue;
}
- }
+ },
+ getRules: function getRules() {
+ var formRules = this.form.rules;
+ var selfRuels = this.rules;
- if (store.lazy !== true && this.data) {
- this.setData(this.data);
+ formRules = formRules ? formRules[this.prop] : [];
- if (store.defaultExpandAll) {
- this.expanded = true;
+ return [].concat(selfRuels || formRules || []);
+ },
+ getFilteredRule: function getFilteredRule(trigger) {
+ var rules = this.getRules();
+
+ return rules.filter(function (rule) {
+ return !rule.trigger || rule.trigger.indexOf(trigger) !== -1;
+ });
+ },
+ onFieldBlur: function onFieldBlur() {
+ this.validate('blur');
+ },
+ onFieldChange: function onFieldChange() {
+ if (this.validateDisabled) {
+ this.validateDisabled = false;
+ return;
}
- } else if (this.level > 0 && store.lazy && store.defaultExpandAll) {
- this.expand();
- }
- 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);
+ this.validate('change');
}
+ },
+ mounted: function mounted() {
+ if (this.prop) {
+ this.dispatch('ElForm', 'el.form.addField', [this]);
- if (key && store.currentNodeKey && this.key === store.currentNodeKey) {
- store.currentNode = this;
- }
+ var initialValue = this.fieldValue;
+ if (Array.isArray(initialValue)) {
+ initialValue = [].concat(initialValue);
+ }
+ Object.defineProperty(this, 'initialValue', {
+ value: initialValue
+ });
- if (store.lazy) {
- store._initDefaultCheckedNode(this);
- }
+ var rules = this.getRules();
- this.updateLeafState();
+ if (rules.length) {
+ this.$on('el.form.blur', this.onFieldBlur);
+ this.$on('el.form.change', this.onFieldChange);
+ }
+ }
+ },
+ beforeDestroy: function beforeDestroy() {
+ this.dispatch('ElForm', 'el.form.removeField', [this]);
}
+ };
- Node.prototype.setData = function setData(data) {
- if (!Array.isArray(data)) {
- (0, _util.markNodeData)(this, data);
- }
+/***/ },
+/* 215 */
+/***/ function(module, exports) {
- this.data = data;
- this.childNodes = [];
+ module.exports = __webpack_require__(56);
- var children = void 0;
- if (this.level === 0 && this.data instanceof Array) {
- children = this.data;
- } else {
- children = getPropertyFromData(this, 'children') || [];
- }
+/***/ },
+/* 216 */
+/***/ function(module, exports) {
- for (var i = 0, j = children.length; i < j; i++) {
- this.insertChild({ data: children[i] });
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-form-item",
+ class: {
+ 'is-error': _vm.validateState === 'error',
+ 'is-validating': _vm.validateState === 'validating',
+ 'is-required': _vm.isRequired || _vm.required
}
- };
-
- Node.prototype.insertChild = function insertChild(child, index) {
- if (!child) throw new Error('insertChild error: child is required.');
-
- if (!(child instanceof Node)) {
- (0, _merge2.default)(child, {
- parent: this,
- store: this.store
- });
- child = new Node(child);
+ }, [(_vm.label || _vm.$slots.label) ? _c('label', {
+ staticClass: "el-form-item__label",
+ style: (_vm.labelStyle),
+ attrs: {
+ "for": _vm.prop
+ }
+ }, [_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) ? _c('div', {
+ staticClass: "el-form-item__error"
+ }, [_vm._v(_vm._s(_vm.validateMessage))]) : _vm._e()])], 2)])
+ },staticRenderFns: []}
- child.level = this.level + 1;
+/***/ },
+/* 217 */
+/***/ function(module, exports, __webpack_require__) {
- if (typeof index === 'undefined' || index < 0) {
- this.childNodes.push(child);
- } else {
- this.childNodes.splice(index, 0, child);
- }
+ 'use strict';
- this.updateLeafState();
- };
+ exports.__esModule = true;
- Node.prototype.insertBefore = function insertBefore(child, ref) {
- var index = void 0;
- if (ref) {
- index = this.childNodes.indexOf(ref);
- }
- this.insertChild(child, index);
- };
+ var _tabs = __webpack_require__(218);
- 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);
- };
+ var _tabs2 = _interopRequireDefault(_tabs);
- Node.prototype.removeChild = function removeChild(child) {
- var index = this.childNodes.indexOf(child);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- if (index > -1) {
- this.store && this.store.deregisterNode(child);
- child.parent = null;
- this.childNodes.splice(index, 1);
- }
+ /* istanbul ignore next */
+ _tabs2.default.install = function (Vue) {
+ Vue.component(_tabs2.default.name, _tabs2.default);
+ };
- this.updateLeafState();
- };
+ exports.default = _tabs2.default;
- Node.prototype.removeChildByData = function removeChildByData(data) {
- var targetNode = null;
- this.childNodes.forEach(function (node) {
- if (node.data === data) {
- targetNode = node;
- }
- });
+/***/ },
+/* 218 */
+/***/ function(module, exports, __webpack_require__) {
- if (targetNode) {
- this.removeChild(targetNode);
- }
- };
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(219),
+ /* template */
+ null,
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- Node.prototype.expand = function expand(callback, expandParent) {
- var _this = this;
+ module.exports = Component.exports
- 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) {
- initLazyLoadChild(_this);
- done();
- }
- });
- } else {
- done();
- }
- };
+/***/ },
+/* 219 */
+/***/ function(module, exports, __webpack_require__) {
- Node.prototype.doCreateChildren = function doCreateChildren(array) {
- var _this2 = this;
+ 'use strict';
- var defaultProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ exports.__esModule = true;
- array.forEach(function (item) {
- _this2.insertChild((0, _merge2.default)({ data: item }, defaultProps));
- });
- };
+ var _tabNav = __webpack_require__(220);
- Node.prototype.collapse = function collapse() {
- this.expanded = false;
- };
+ var _tabNav2 = _interopRequireDefault(_tabNav);
- Node.prototype.shouldLoadData = function shouldLoadData() {
- return this.store.lazy === true && this.store.load && !this.loaded;
- };
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- 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;
-
- var _getChildState2 = getChildState(this.childNodes),
- all = _getChildState2.all,
- allWithoutDisable = _getChildState2.allWithoutDisable;
-
- if (this.childNodes.length && !all && allWithoutDisable) {
- this.checked = false;
- value = false;
- }
+ exports.default = {
+ name: 'ElTabs',
- var handleDescendants = function handleDescendants(lazy) {
- if (deep && !lazy) {
- 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);
- }
+ components: {
+ TabNav: _tabNav2.default
+ },
- var _getChildState3 = getChildState(childNodes),
- half = _getChildState3.half,
- _all = _getChildState3.all;
+ props: {
+ type: String,
+ activeName: String,
+ closable: Boolean,
+ addable: Boolean,
+ value: {},
+ editable: Boolean
+ },
- if (!_all) {
- _this3.checked = _all;
- _this3.indeterminate = half;
- }
- }
+ data: function data() {
+ return {
+ currentName: this.value || this.activeName,
+ panes: []
};
+ },
- if (!this.store.checkStrictly && this.shouldLoadData()) {
- // Only work on lazy load data.
- this.loadData(function () {
- handleDescendants(true);
- }, {
- checked: value !== false
- });
- } else {
- handleDescendants();
- }
-
- var parent = this.parent;
- if (!parent || parent.level === 0) return;
-
- if (!this.store.checkStrictly && !recursion) {
- reInitChecked(parent);
- }
- };
-
- Node.prototype.getChildren = function getChildren() {
- // this is data
- var data = this.data;
- if (!data) return null;
- var props = this.store.props;
- var children = 'children';
- if (props) {
- children = props.children || 'children';
- }
+ watch: {
+ activeName: function activeName(value) {
+ this.setCurrentName(value);
+ },
+ value: function value(_value) {
+ this.setCurrentName(_value);
+ },
+ currentName: function currentName(value) {
+ var _this = this;
- if (data[children] === undefined) {
- data[children] = null;
+ if (this.$refs.nav) {
+ this.$nextTick(function (_) {
+ _this.$refs.nav.scrollToActiveTab();
+ });
+ }
}
+ },
- 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) {
- if (item[_util.NODE_KEY]) {
- newDataMap[item[_util.NODE_KEY]] = { index: index, data: item };
- } else {
- newNodes.push({ index: index, data: item });
+ methods: {
+ 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) {
+ this.currentName = value;
+ this.$emit('input', value);
+ },
+ addPanes: function addPanes(item) {
+ var index = this.$slots.default.filter(function (item) {
+ return item.elm.nodeType === 1 && /\bel-tab-pane\b/.test(item.elm.className);
+ }).indexOf(item.$vnode);
+ this.panes.splice(index, 0, item);
+ },
+ removePanes: function removePanes(item) {
+ var panes = this.panes;
+ var index = panes.indexOf(item);
+ if (index > -1) {
+ panes.splice(index, 1);
}
- });
-
- oldData.forEach(function (item) {
- if (!newDataMap[item[_util.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 = [];
+ }
+ },
+ render: function render(h) {
+ 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;
- _this5.doCreateChildren(children, defaultProps);
- _this5.updateLeafState();
- if (callback) {
- callback.call(_this5, children);
+ var newButton = editable || addable ? h(
+ 'span',
+ {
+ 'class': 'el-tabs__new-tab',
+ on: {
+ 'click': handleTabAdd
}
- };
+ },
+ [h(
+ 'i',
+ { 'class': 'el-icon-plus' },
+ []
+ )]
+ ) : null;
- this.store.load(this, resolve);
- } else {
- if (callback) {
- callback.call(this);
- }
- }
- };
+ var navData = {
+ props: {
+ currentName: currentName,
+ onTabClick: handleTabClick,
+ onTabRemove: handleTabRemove,
+ editable: editable,
+ type: type,
+ panes: panes
+ },
+ ref: 'nav'
+ };
- _createClass(Node, [{
- key: 'label',
- get: function get() {
- return getPropertyFromData(this, 'label');
- }
- }, {
- key: 'icon',
- get: function get() {
- return getPropertyFromData(this, 'icon');
- }
- }, {
- 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');
+ return h(
+ 'div',
+ { 'class': {
+ 'el-tabs': true,
+ 'el-tabs--card': type === 'card',
+ 'el-tabs--border-card': type === 'border-card'
+ } },
+ [h(
+ 'div',
+ { 'class': 'el-tabs__header' },
+ [newButton, h(
+ 'tab-nav',
+ navData,
+ []
+ )]
+ ), h(
+ 'div',
+ { 'class': 'el-tabs__content' },
+ [this.$slots.default]
+ )]
+ );
+ },
+ created: function created() {
+ if (!this.currentName) {
+ this.setCurrentName('0');
}
- }]);
-
- return Node;
- }();
-
- exports.default = Node;
-
-/***/ },
-/* 238 */
-/***/ function(module, exports) {
-
- 'use strict';
-
- exports.__esModule = true;
- var NODE_KEY = exports.NODE_KEY = '$treeNodeId';
-
- var markNodeData = exports.markNodeData = function markNodeData(node, data) {
- if (data[NODE_KEY]) return;
- Object.defineProperty(data, NODE_KEY, {
- value: node.id,
- enumerable: false,
- configurable: false,
- writable: false
- });
- };
-
- var getNodeKey = exports.getNodeKey = function getNodeKey(key, data) {
- if (!key) return data[NODE_KEY];
- return data[key];
+ }
};
/***/ },
-/* 239 */
+/* 220 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(240),
+ __webpack_require__(221),
/* template */
- __webpack_require__(241),
+ null,
/* styles */
null,
/* scopeId */
@@ -52787,370 +52588,351 @@ module.exports =
/***/ },
-/* 240 */
+/* 221 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _collapseTransition = __webpack_require__(49);
-
- var _collapseTransition2 = _interopRequireDefault(_collapseTransition);
-
- var _checkbox = __webpack_require__(130);
-
- var _checkbox2 = _interopRequireDefault(_checkbox);
+ var _tabBar = __webpack_require__(222);
- var _emitter = __webpack_require__(15);
+ var _tabBar2 = _interopRequireDefault(_tabBar);
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _resizeEvent = __webpack_require__(110);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- exports.default = {
- name: 'ElTreeNode',
+ function noop() {}
- componentName: 'ElTreeNode',
+ exports.default = {
+ name: 'TabNav',
- mixins: [_emitter2.default],
+ components: {
+ TabBar: _tabBar2.default
+ },
props: {
- node: {
- default: function _default() {
- return {};
- }
+ panes: Array,
+ currentName: String,
+ editable: Boolean,
+ onTabClick: {
+ type: Function,
+ default: noop
},
- props: {},
- renderContent: Function
- },
-
- components: {
- ElCollapseTransition: _collapseTransition2.default,
- ElCheckbox: _checkbox2.default,
- NodeContent: {
- props: {
- node: {
- required: true
- }
- },
- render: function render(h) {
- var parent = this.$parent;
- var node = this.node;
- var data = node.data;
- var store = node.store;
- return parent.renderContent ? parent.renderContent.call(parent._renderProxy, h, { _self: parent.tree.$vnode.context, node: node, data: data, store: store }) : h(
- 'span',
- { 'class': 'el-tree-node__label' },
- [this.node.label]
- );
- }
- }
+ onTabRemove: {
+ type: Function,
+ default: noop
+ },
+ type: String
},
data: function data() {
return {
- tree: null,
- expanded: false,
- childNodeRendered: false,
- showCheckbox: false,
- oldChecked: null,
- oldIndeterminate: null
+ scrollable: false,
+ navStyle: {
+ transform: ''
+ }
};
},
- watch: {
- 'node.indeterminate': function nodeIndeterminate(val) {
- this.handleSelectChange(this.node.checked, val);
+ methods: {
+ scrollPrev: function scrollPrev() {
+ var containerWidth = this.$refs.navScroll.offsetWidth;
+ var currentOffset = this.getCurrentScrollOffset();
+
+ if (!currentOffset) return;
+
+ var newOffset = currentOffset > containerWidth ? currentOffset - containerWidth : 0;
+
+ this.setOffset(newOffset);
},
- 'node.checked': function nodeChecked(val) {
- this.handleSelectChange(val, this.node.indeterminate);
+ scrollNext: function scrollNext() {
+ var navWidth = this.$refs.nav.offsetWidth;
+ var containerWidth = this.$refs.navScroll.offsetWidth;
+ var currentOffset = this.getCurrentScrollOffset();
+
+ if (navWidth - currentOffset <= containerWidth) return;
+
+ var newOffset = navWidth - currentOffset > containerWidth * 2 ? currentOffset + containerWidth : navWidth - containerWidth;
+
+ this.setOffset(newOffset);
},
- 'node.expanded': function nodeExpanded(val) {
- this.expanded = val;
- if (val) {
- this.childNodeRendered = true;
- }
- }
- },
+ scrollToActiveTab: function scrollToActiveTab() {
+ if (!this.scrollable) return;
+ var nav = this.$refs.nav;
+ var activeTab = this.$el.querySelector('.is-active');
+ var navScroll = this.$refs.navScroll;
+ var activeTabBounding = activeTab.getBoundingClientRect();
+ var navScrollBounding = navScroll.getBoundingClientRect();
+ var navBounding = nav.getBoundingClientRect();
+ var currentOffset = this.getCurrentScrollOffset();
+ var newOffset = currentOffset;
- methods: {
- getNodeKey: function getNodeKey(node, index) {
- var nodeKey = this.tree.nodeKey;
- if (nodeKey && node) {
- return node.data[nodeKey];
+ if (activeTabBounding.left < navScrollBounding.left) {
+ newOffset = currentOffset - (navScrollBounding.left - activeTabBounding.left);
}
- return index;
- },
- handleSelectChange: function handleSelectChange(checked, indeterminate) {
- if (this.oldChecked !== checked && this.oldIndeterminate !== indeterminate) {
- this.tree.$emit('check-change', this.node.data, checked, indeterminate);
+ if (activeTabBounding.right > navScrollBounding.right) {
+ newOffset = currentOffset + activeTabBounding.right - navScrollBounding.right;
}
- 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 (navBounding.right < navScrollBounding.right) {
+ newOffset = nav.offsetWidth - navScrollBounding.width;
}
- this.tree.$emit('node-click', this.node.data, this.node, this);
+ this.setOffset(Math.max(newOffset, 0));
},
- 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);
- }
+ getCurrentScrollOffset: function getCurrentScrollOffset() {
+ var navStyle = this.navStyle;
+
+ return navStyle.transform ? Number(navStyle.transform.match(/translateX\(-(\d+(\.\d+)*)px\)/)[1]) : 0;
},
- handleCheckChange: function handleCheckChange(ev) {
- this.node.setChecked(ev.target.checked, !this.tree.checkStrictly);
+ setOffset: function setOffset(value) {
+ this.navStyle.transform = 'translateX(-' + value + 'px)';
},
- handleChildNodeExpand: function handleChildNodeExpand(nodeData, node, instance) {
- this.broadcast('ElTreeNode', 'tree-node-expand', node);
- this.tree.$emit('node-expand', nodeData, node, instance);
+ update: function update() {
+ var navWidth = this.$refs.nav.offsetWidth;
+ var containerWidth = this.$refs.navScroll.offsetWidth;
+ var currentOffset = this.getCurrentScrollOffset();
+
+ if (containerWidth < navWidth) {
+ var _currentOffset = this.getCurrentScrollOffset();
+ this.scrollable = this.scrollable || {};
+ this.scrollable.prev = _currentOffset;
+ this.scrollable.next = _currentOffset + containerWidth < navWidth;
+ if (navWidth - _currentOffset < containerWidth) {
+ this.setOffset(navWidth - containerWidth);
+ }
+ } else {
+ this.scrollable = false;
+ if (currentOffset > 0) {
+ this.setOffset(0);
+ }
+ }
}
},
- created: function created() {
- var _this = this;
+ updated: function updated() {
+ this.update();
+ },
+ render: function render(h) {
+ var type = this.type,
+ panes = this.panes,
+ editable = this.editable,
+ onTabClick = this.onTabClick,
+ onTabRemove = this.onTabRemove,
+ navStyle = this.navStyle,
+ scrollable = this.scrollable,
+ scrollNext = this.scrollNext,
+ scrollPrev = this.scrollPrev;
- var parent = this.$parent;
- if (parent.isTree) {
- this.tree = parent;
- } else {
- this.tree = parent.tree;
- }
+ 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 tree = this.tree;
- if (!tree) {
- console.warn('Can not find node\'s tree.');
- }
+ var tabs = this._l(panes, function (pane, index) {
+ var tabName = pane.name || pane.index || index;
+ var closable = pane.isClosable || editable;
- var props = tree.props || {};
- var childrenKey = props['children'] || 'children';
+ pane.index = '' + index;
- this.$watch('node.data.' + childrenKey, function () {
- _this.node.updateChildren();
+ 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;
+ return h(
+ 'div',
+ {
+ 'class': {
+ 'el-tabs__item': true,
+ 'is-active': pane.active,
+ 'is-disabled': pane.disabled,
+ 'is-closable': closable
+ },
+ ref: 'tabs',
+ refInFor: true,
+ on: {
+ 'click': function click(ev) {
+ onTabClick(pane, tabName, ev);
+ }
+ }
+ },
+ [tabLabelContent, btnClose]
+ );
});
+ return h(
+ 'div',
+ { 'class': ['el-tabs__nav-wrap', scrollable ? 'is-scrollable' : ''] },
+ [scrollBtn, h(
+ 'div',
+ { 'class': ['el-tabs__nav-scroll'], ref: 'navScroll' },
+ [h(
+ 'div',
+ { 'class': 'el-tabs__nav', ref: 'nav', style: navStyle },
+ [!type ? h(
+ 'tab-bar',
+ {
+ attrs: { tabs: panes }
+ },
+ []
+ ) : null, tabs]
+ )]
+ )]
+ );
+ },
+ mounted: function mounted() {
+ (0, _resizeEvent.addResizeListener)(this.$el, this.update);
+ },
+ beforeDestroy: function beforeDestroy() {
+ if (this.$el && this.update) (0, _resizeEvent.removeResizeListener)(this.$el, this.update);
+ }
+ };
- this.showCheckbox = tree.showCheckbox;
+/***/ },
+/* 222 */
+/***/ function(module, exports, __webpack_require__) {
- if (this.node.expanded) {
- this.expanded = true;
- this.childNodeRendered = true;
- }
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(223),
+ /* template */
+ __webpack_require__(224),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- if (this.tree.accordion) {
- this.$on('tree-node-expand', function (node) {
- if (_this.node !== node) {
- _this.node.collapse();
- }
- });
- }
- }
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ module.exports = Component.exports
+
+
+/***/ },
+/* 223 */
+/***/ function(module, exports) {
+
+ 'use strict';
+
+ exports.__esModule = true;
//
//
//
-/***/ },
-/* 241 */
-/***/ function(module, exports) {
+ exports.default = {
+ name: 'TabBar',
- module.exports={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.node.visible),
- expression: "node.visible"
- }],
- staticClass: "el-tree-node",
- class: {
- 'is-expanded': _vm.childNodeRendered && _vm.expanded,
- 'is-current': _vm.tree.store.currentNode === _vm.node,
- 'is-hidden': !_vm.node.visible
- },
- on: {
- "click": function($event) {
- $event.stopPropagation();
- _vm.handleClick($event)
- }
- }
- }, [_c('div', {
- staticClass: "el-tree-node__content",
- style: ({
- 'padding-left': (_vm.node.level - 1) * _vm.tree.indent + 'px'
- })
- }, [_c('span', {
- staticClass: "el-tree-node__expand-icon",
- class: {
- 'is-leaf': _vm.node.isLeaf, expanded: !_vm.node.isLeaf && _vm.expanded
- },
- on: {
- "click": function($event) {
- $event.stopPropagation();
- _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();
+ props: {
+ tabs: Array
+ },
+
+ computed: {
+ barStyle: {
+ cache: false,
+ get: function get() {
+ var _this = this;
+
+ if (!this.$parent.$refs.tabs) return {};
+ var style = {};
+ var offset = 0;
+ var tabWidth = 0;
+
+ this.tabs.every(function (tab, index) {
+ var $el = _this.$parent.$refs.tabs[index];
+ if (!$el) {
+ return false;
+ }
+
+ if (!tab.active) {
+ offset += $el.clientWidth;
+ return true;
+ } else {
+ tabWidth = $el.clientWidth;
+ return false;
+ }
+ });
+
+ var transform = 'translateX(' + offset + 'px)';
+ style.width = tabWidth + 'px';
+ style.transform = transform;
+ style.msTransform = transform;
+ style.webkitTransform = transform;
+
+ return style;
}
- },
- model: {
- value: (_vm.node.checked),
- callback: function($$v) {
- _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', [_c('div', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.expanded),
- expression: "expanded"
- }],
- staticClass: "el-tree-node__children"
- }, _vm._l((_vm.node.childNodes), function(child) {
- return _c('el-tree-node', {
- key: _vm.getNodeKey(child),
- attrs: {
- "render-content": _vm.renderContent,
- "node": child
- },
- on: {
- "node-expand": _vm.handleChildNodeExpand
- }
- })
- }))])], 1)
- },staticRenderFns: []}
+ }
+ };
/***/ },
-/* 242 */
+/* 224 */
/***/ function(module, exports) {
module.exports={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
- }
- }, [_vm._l((_vm.root.childNodes), function(child) {
- return _c('el-tree-node', {
- key: _vm.getNodeKey(child),
- attrs: {
- "node": child,
- "props": _vm.props,
- "render-content": _vm.renderContent
- },
- on: {
- "node-expand": _vm.handleNodeExpand
- }
- })
- }), (!_vm.root.childNodes || _vm.root.childNodes.length === 0) ? _c('div', {
- staticClass: "el-tree__empty-block"
- }, [_c('span', {
- staticClass: "el-tree__empty-text"
- }, [_vm._v(_vm._s(_vm.emptyText))])]) : _vm._e()], 2)
+ staticClass: "el-tabs__active-bar",
+ style: (_vm.barStyle)
+ })
},staticRenderFns: []}
/***/ },
-/* 243 */
+/* 225 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(244);
+ var _tabPane = __webpack_require__(226);
- var _main2 = _interopRequireDefault(_main);
+ var _tabPane2 = _interopRequireDefault(_tabPane);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _main2.default.install = function (Vue) {
- Vue.component(_main2.default.name, _main2.default);
+ _tabPane2.default.install = function (Vue) {
+ Vue.component(_tabPane2.default.name, _tabPane2.default);
};
- exports.default = _main2.default;
+ exports.default = _tabPane2.default;
/***/ },
-/* 244 */
+/* 226 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(245),
+ __webpack_require__(227),
/* template */
- __webpack_require__(246),
+ __webpack_require__(228),
/* styles */
null,
/* scopeId */
@@ -53163,7 +52945,7 @@ module.exports =
/***/ },
-/* 245 */
+/* 227 */
/***/ function(module, exports) {
'use strict';
@@ -53174,264 +52956,113 @@ module.exports =
//
//
//
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- var TYPE_CLASSES_MAP = {
- 'success': 'el-icon-circle-check',
- 'warning': 'el-icon-warning',
- 'error': 'el-icon-circle-cross'
- };
exports.default = {
- name: 'ElAlert',
+ name: 'ElTabPane',
+
+ componentName: 'ElTabPane',
props: {
- title: {
- type: String,
- default: '',
- required: true
- },
- description: {
- type: String,
- default: ''
- },
- type: {
- type: String,
- default: 'info'
- },
- closable: {
- type: Boolean,
- default: true
- },
- closeText: {
- type: String,
- default: ''
- },
- showIcon: {
- type: Boolean,
- default: false
- }
+ label: String,
+ labelContent: Function,
+ name: String,
+ closable: Boolean,
+ disabled: Boolean
},
data: function data() {
return {
- visible: true
+ index: null
};
},
- methods: {
- close: function close() {
- this.visible = false;
- this.$emit('close');
+ computed: {
+ isClosable: function isClosable() {
+ return this.closable || this.$parent.closable;
+ },
+ active: function active() {
+ return this.$parent.currentName === (this.name || this.index);
}
},
- computed: {
- typeClass: function typeClass() {
- return 'el-alert--' + this.type;
- },
- iconClass: function iconClass() {
- return TYPE_CLASSES_MAP[this.type] || 'el-icon-information';
- },
- isBigIcon: function isBigIcon() {
- return this.description || this.$slots.default ? 'is-big' : '';
- },
- isBoldTitle: function isBoldTitle() {
- return this.description || this.$slots.default ? 'is-bold' : '';
+ mounted: function mounted() {
+ this.$parent.addPanes(this);
+ },
+ destroyed: function destroyed() {
+ if (this.$el && this.$el.parentNode) {
+ this.$el.parentNode.removeChild(this.$el);
+ }
+ this.$parent.removePanes(this);
+ },
+
+
+ watch: {
+ label: function label() {
+ this.$parent.$forceUpdate();
}
}
};
/***/ },
-/* 246 */
+/* 228 */
/***/ function(module, exports) {
module.exports={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.showIcon) ? _c('i', {
- staticClass: "el-alert__icon",
- class: [_vm.iconClass, _vm.isBigIcon]
- }) : _vm._e(), _c('div', {
- staticClass: "el-alert__content"
- }, [(_vm.title) ? _c('span', {
- staticClass: "el-alert__title",
- class: [_vm.isBoldTitle]
- }, [_vm._v(_vm._s(_vm.title))]) : _vm._e(), _vm._t("default", [(_vm.description) ? _c('p', {
- staticClass: "el-alert__description"
- }, [_vm._v(_vm._s(_vm.description))]) : _vm._e()]), _c('i', {
+ return _c('div', {
directives: [{
name: "show",
rawName: "v-show",
- value: (_vm.closable),
- expression: "closable"
+ value: (_vm.active),
+ expression: "active"
}],
- 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))])], 2)])])
+ staticClass: "el-tab-pane"
+ }, [_vm._t("default")], 2)
},staticRenderFns: []}
/***/ },
-/* 247 */
+/* 229 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(248);
+ var _tag = __webpack_require__(230);
- var _main2 = _interopRequireDefault(_main);
+ var _tag2 = _interopRequireDefault(_tag);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- exports.default = _main2.default;
+ /* istanbul ignore next */
+ _tag2.default.install = function (Vue) {
+ Vue.component(_tag2.default.name, _tag2.default);
+ };
+
+ exports.default = _tag2.default;
/***/ },
-/* 248 */
+/* 230 */
/***/ function(module, exports, __webpack_require__) {
- 'use strict';
-
- exports.__esModule = true;
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(231),
+ /* template */
+ __webpack_require__(232),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- var _vue = __webpack_require__(133);
-
- var _vue2 = _interopRequireDefault(_vue);
-
- var _popup = __webpack_require__(14);
-
- var _vdom = __webpack_require__(194);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- var NotificationConstructor = _vue2.default.extend(__webpack_require__(249));
-
- var instance = void 0;
- var instances = [];
- var seed = 1;
-
- var Notification = function Notification(options) {
- if (_vue2.default.prototype.$isServer) return;
- options = options || {};
- var userOnClose = options.onClose;
- var id = 'notification_' + seed++;
-
- options.onClose = function () {
- Notification.close(id, userOnClose);
- };
-
- instance = new NotificationConstructor({
- data: options
- });
-
- if ((0, _vdom.isVNode)(options.message)) {
- instance.$slots.default = [options.message];
- options.message = '';
- }
- instance.id = id;
- instance.vm = instance.$mount();
- document.body.appendChild(instance.vm.$el);
- instance.vm.visible = true;
- instance.dom = instance.vm.$el;
- instance.dom.style.zIndex = _popup.PopupManager.nextZIndex();
-
- var offset = options.offset || 0;
- var topDist = offset;
- for (var i = 0, len = instances.length; i < len; i++) {
- topDist += instances[i].$el.offsetHeight + 16;
- }
- topDist += 16;
- instance.top = topDist;
- instances.push(instance);
- return instance.vm;
- };
-
- ['success', 'warning', 'info', 'error'].forEach(function (type) {
- Notification[type] = function (options) {
- if (typeof options === 'string' || (0, _vdom.isVNode)(options)) {
- options = {
- message: options
- };
- }
- options.type = type;
- return Notification(options);
- };
- });
-
- Notification.close = function (id, userOnClose) {
- var index = void 0;
- var removedHeight = void 0;
- for (var i = 0, len = instances.length; i < len; i++) {
- if (id === instances[i].id) {
- if (typeof userOnClose === 'function') {
- userOnClose(instances[i]);
- }
- index = i;
- removedHeight = instances[i].dom.offsetHeight;
- instances.splice(i, 1);
- break;
- }
- }
-
- if (len > 1) {
- for (i = index; i < len - 1; i++) {
- instances[i].dom.style.top = parseInt(instances[i].dom.style.top, 10) - removedHeight - 16 + 'px';
- }
- }
- };
-
- exports.default = Notification;
-
-/***/ },
-/* 249 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(250),
- /* template */
- __webpack_require__(251),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
+ module.exports = Component.exports
/***/ },
-/* 250 */
+/* 231 */
/***/ function(module, exports) {
'use strict';
@@ -53450,191 +53081,79 @@ module.exports =
//
//
//
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
-
- var typeMap = {
- success: 'circle-check',
- info: 'information',
- warning: 'warning',
- error: 'circle-cross'
- };
exports.default = {
- data: function data() {
- return {
- visible: false,
- title: '',
- message: '',
- duration: 4500,
- type: '',
- customClass: '',
- iconClass: '',
- onClose: null,
- onClick: null,
- closed: false,
- top: null,
- timer: null
- };
- },
-
-
- computed: {
- typeClass: function typeClass() {
- return this.type && typeMap[this.type] ? 'el-icon-' + typeMap[this.type] : '';
- }
- },
-
- watch: {
- closed: function closed(newVal) {
- if (newVal) {
- this.visible = false;
- this.$el.addEventListener('transitionend', this.destroyElement);
- }
- }
+ name: 'ElTag',
+ props: {
+ text: String,
+ closable: Boolean,
+ type: String,
+ hit: Boolean,
+ closeTransition: Boolean,
+ color: String
},
-
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);
- }
- }
- },
-
- mounted: function mounted() {
- var _this2 = this;
-
- if (this.duration > 0) {
- this.timer = setTimeout(function () {
- if (!_this2.closed) {
- _this2.close();
- }
- }, this.duration);
+ handleClose: function handleClose(event) {
+ this.$emit('close', event);
}
}
};
/***/ },
-/* 251 */
+/* 232 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
return _c('transition', {
attrs: {
- "name": "el-notification-fade"
+ "name": _vm.closeTransition ? '' : 'el-zoom-in-center'
}
- }, [_c('div', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.visible),
- expression: "visible"
+ }, [_c('span', {
+ staticClass: "el-tag",
+ class: [_vm.type ? 'el-tag--' + _vm.type : '', {
+ 'is-hit': _vm.hit
}],
- staticClass: "el-notification",
- class: _vm.customClass,
style: ({
- top: _vm.top ? _vm.top + 'px' : 'auto'
- }),
- 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', {
- staticClass: "el-notification__content"
- }, [_vm._t("default", [_vm._v(_vm._s(_vm.message))])], 2), _c('div', {
- staticClass: "el-notification__closeBtn el-icon-close",
+ backgroundColor: _vm.color
+ })
+ }, [_vm._t("default"), (_vm.closable) ? _c('i', {
+ staticClass: "el-tag__close el-icon-close",
on: {
- "click": function($event) {
- $event.stopPropagation();
- _vm.close($event)
- }
+ "click": _vm.handleClose
}
- })])])])
+ }) : _vm._e()], 2)])
},staticRenderFns: []}
/***/ },
-/* 252 */
+/* 233 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(253);
+ var _tree = __webpack_require__(234);
- var _main2 = _interopRequireDefault(_main);
+ var _tree2 = _interopRequireDefault(_tree);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _main2.default.install = function (Vue) {
- Vue.component(_main2.default.name, _main2.default);
+ _tree2.default.install = function (Vue) {
+ Vue.component(_tree2.default.name, _tree2.default);
};
- exports.default = _main2.default;
+ exports.default = _tree2.default;
/***/ },
-/* 253 */
+/* 234 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(254),
+ __webpack_require__(235),
/* template */
- __webpack_require__(259),
+ __webpack_require__(242),
/* styles */
null,
/* scopeId */
@@ -53647,20 +53166,18 @@ module.exports =
/***/ },
-/* 254 */
+/* 235 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _inputNumber = __webpack_require__(255);
-
- var _inputNumber2 = _interopRequireDefault(_inputNumber);
+ var _treeStore = __webpack_require__(236);
- var _button = __webpack_require__(256);
+ var _treeStore2 = _interopRequireDefault(_treeStore);
- var _button2 = _interopRequireDefault(_button);
+ var _locale = __webpack_require__(111);
var _emitter = __webpack_require__(15);
@@ -53669,274 +53186,159 @@ module.exports =
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElSlider',
+ name: 'ElTree',
mixins: [_emitter2.default],
+ components: {
+ ElTreeNode: __webpack_require__(239)
+ },
+
+ data: function data() {
+ return {
+ store: null,
+ root: null,
+ currentNode: null
+ };
+ },
+
+
props: {
- min: {
- type: Number,
- default: 0
- },
- max: {
- type: Number,
- default: 100
- },
- step: {
- type: Number,
- default: 1
- },
- value: {
- type: [Number, Array],
- default: 0
+ data: {
+ type: Array
},
- showInput: {
- type: Boolean,
- default: false
+ emptyText: {
+ type: String,
+ default: function _default() {
+ return (0, _locale.t)('el.tree.emptyText');
+ }
},
- showInputControls: {
+ nodeKey: String,
+ checkStrictly: Boolean,
+ defaultExpandAll: Boolean,
+ expandOnClickNode: {
type: Boolean,
default: true
},
- showStops: {
- type: Boolean,
- default: false
- },
- showTooltip: {
+ autoExpandParent: {
type: Boolean,
default: true
},
- formatTooltip: Function,
- disabled: {
+ defaultCheckedKeys: Array,
+ defaultExpandedKeys: Array,
+ renderContent: Function,
+ showCheckbox: {
type: Boolean,
default: false
},
- range: {
- type: Boolean,
- default: false
+ props: {
+ default: function _default() {
+ return {
+ children: 'children',
+ label: 'label',
+ icon: 'icon',
+ disabled: 'disabled'
+ };
+ }
},
- vertical: {
+ lazy: {
type: Boolean,
default: false
},
- height: {
- type: String
- },
- debounce: {
+ highlightCurrent: Boolean,
+ currentNodeKey: [String, Number],
+ load: Function,
+ filterNodeMethod: Function,
+ accordion: Boolean,
+ indent: {
type: Number,
- default: 300
+ default: 16
}
},
- components: {
- ElInputNumber: _inputNumber2.default,
- SliderButton: _button2.default
- },
-
- data: function data() {
- return {
- firstValue: null,
- secondValue: null,
- oldValue: null,
- dragging: false,
- sliderSize: 1
- };
+ computed: {
+ children: {
+ set: function set(value) {
+ this.data = value;
+ },
+ get: function get() {
+ return this.data;
+ }
+ }
},
-
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);
- }
+ defaultCheckedKeys: function defaultCheckedKeys(newVal) {
+ this.store.defaultCheckedKeys = newVal;
+ this.store.setDefaultCheckedKey(newVal);
},
- secondValue: function secondValue() {
- if (this.range) {
- this.$emit('input', [this.minValue, this.maxValue]);
- }
+ defaultExpandedKeys: function defaultExpandedKeys(newVal) {
+ this.store.defaultExpandedKeys = newVal;
+ this.store.setDefaultExpandedKeys(newVal);
},
- min: function min() {
- this.setValues();
+ currentNodeKey: function currentNodeKey(newVal) {
+ this.store.setCurrentNodeKey(newVal);
+ this.store.currentNodeKey = newVal;
},
- max: function max() {
- this.setValues();
+ data: function data(newVal) {
+ this.store.setData(newVal);
}
},
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;
- }
+ filter: function filter(value) {
+ if (!this.filterNodeMethod) throw new Error('[Tree] filterNodeMethod is required when filter');
+ this.store.filter(value);
},
- setValues: function setValues() {
- 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.$emit('change', [this.minValue, this.maxValue]);
- 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.$emit('change', val);
- this.dispatch('ElFormItem', 'el.form.change', val);
- this.oldValue = val;
- }
- }
+ getNodeKey: function getNodeKey(node, index) {
+ var nodeKey = this.nodeKey;
+ if (nodeKey && node) {
+ return node.data[nodeKey];
}
+ return index;
},
- 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);
+ getCheckedNodes: function getCheckedNodes(leafOnly) {
+ return this.store.getCheckedNodes(leafOnly);
},
- onSliderClick: function onSliderClick(event) {
- if (this.disabled || 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);
- }
+ getCheckedKeys: function getCheckedKeys(leafOnly) {
+ return this.store.getCheckedKeys(leafOnly);
},
- resetSize: function resetSize() {
- if (this.$refs.slider) {
- this.sliderSize = this.$refs.slider['client' + (this.vertical ? 'Height' : 'Width')];
- }
- }
- },
-
- computed: {
- stops: function stops() {
- var _this2 = this;
-
- if (this.step === 0) {
- ("production") !== 'production' && console.warn('[Element Warn][Slider]step should not be 0.');
- 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 * (_this2.minValue - _this2.min) / (_this2.max - _this2.min) || step > 100 * (_this2.maxValue - _this2.min) / (_this2.max - _this2.min);
- });
- } else {
- return result.filter(function (step) {
- return step > 100 * (_this2.firstValue - _this2.min) / (_this2.max - _this2.min);
- });
- }
- },
- 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%';
+ setCheckedNodes: function setCheckedNodes(nodes, leafOnly) {
+ if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCheckedNodes');
+ this.store.setCheckedNodes(nodes, leafOnly);
},
- 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);
+ setCheckedKeys: function setCheckedKeys(keys, leafOnly) {
+ if (!this.nodeKey) throw new Error('[Tree] nodeKey is required in setCheckedNodes');
+ this.store.setCheckedKeys(keys, leafOnly);
},
- runwayStyle: function runwayStyle() {
- return this.vertical ? { height: this.height } : {};
+ setChecked: function setChecked(data, checked, deep) {
+ this.store.setChecked(data, checked, deep);
},
- barStyle: function barStyle() {
- return this.vertical ? {
- height: this.barSize,
- bottom: this.barStart
- } : {
- width: this.barSize,
- left: this.barStart
- };
+ handleNodeExpand: function handleNodeExpand(nodeData, node, instance) {
+ this.broadcast('ElTreeNode', 'tree-node-expand', node);
+ this.$emit('node-expand', nodeData, node, instance);
}
},
- mounted: function mounted() {
- 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];
- } 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;
- }
- this.resetSize();
- window.addEventListener('resize', this.resetSize);
- },
- beforeDestroy: function beforeDestroy() {
- window.removeEventListener('resize', this.resetSize);
+ created: function created() {
+ this.isTree = true;
+
+ this.store = new _treeStore2.default({
+ key: this.nodeKey,
+ data: this.data,
+ lazy: this.lazy,
+ props: this.props,
+ load: this.load,
+ currentNodeKey: this.currentNodeKey,
+ checkStrictly: this.checkStrictly,
+ defaultCheckedKeys: this.defaultCheckedKeys,
+ defaultExpandedKeys: this.defaultExpandedKeys,
+ autoExpandParent: this.autoExpandParent,
+ defaultExpandAll: this.defaultExpandAll,
+ filterNodeMethod: this.filterNodeMethod
+ });
+
+ this.root = this.store.root;
}
}; //
//
@@ -53954,1015 +53356,851 @@ module.exports =
//
//
//
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
-
-/***/ },
-/* 255 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(76);
/***/ },
-/* 256 */
+/* 236 */
/***/ function(module, exports, __webpack_require__) {
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(257),
- /* template */
- __webpack_require__(258),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ 'use strict';
- module.exports = Component.exports
+ exports.__esModule = true;
+ 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; };
-/***/ },
-/* 257 */
-/***/ function(module, exports, __webpack_require__) {
+ var _node = __webpack_require__(237);
- 'use strict';
+ var _node2 = _interopRequireDefault(_node);
- exports.__esModule = true;
+ var _util = __webpack_require__(238);
- var _tooltip = __webpack_require__(138);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var _tooltip2 = _interopRequireDefault(_tooltip);
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var TreeStore = function () {
+ function TreeStore(options) {
+ var _this = this;
- exports.default = {
- name: 'ElSliderButton',
+ _classCallCheck(this, TreeStore);
- components: {
- ElTooltip: _tooltip2.default
- },
+ this.currentNode = null;
+ this.currentNodeKey = null;
- props: {
- value: {
- type: Number,
- default: 0
- },
- vertical: {
- type: Boolean,
- default: false
+ for (var option in options) {
+ if (options.hasOwnProperty(option)) {
+ this[option] = options[option];
+ }
}
- },
- data: function data() {
- return {
- hovering: false,
- dragging: false,
- startX: 0,
- currentX: 0,
- startY: 0,
- currentY: 0,
- startPosition: 0,
- newPosition: null,
- oldValue: this.value
- };
- },
+ this.nodesMap = {};
+ this.root = new _node2.default({
+ data: this.data,
+ store: this
+ });
- computed: {
- disabled: function disabled() {
- return this.$parent.disabled;
- },
- 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 };
+ if (this.lazy && this.load) {
+ var loadFn = this.load;
+ loadFn(this.root, function (data) {
+ _this.root.doCreateChildren(data);
+ _this._initDefaultCheckedNodes();
+ });
+ } else {
+ this._initDefaultCheckedNodes();
}
- },
+ }
- watch: {
- dragging: function dragging(val) {
- this.$parent.dragging = val;
- }
- },
+ TreeStore.prototype.filter = function filter(value) {
+ var filterNodeMethod = this.filterNodeMethod;
+ var traverse = function traverse(node) {
+ var childNodes = node.root ? node.root.childNodes : node.childNodes;
- 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('mouseup', this.onDragEnd);
- window.addEventListener('contextmenu', this.onDragEnd);
- },
- onDragStart: function onDragStart(event) {
- this.dragging = true;
- if (this.vertical) {
- this.startY = event.clientY;
- } else {
- this.startX = event.clientX;
- }
- this.startPosition = parseFloat(this.currentPosition);
- },
- onDragging: function onDragging(event) {
- if (this.dragging) {
- this.displayTooltip();
- this.$parent.resetSize();
- var diff = 0;
- if (this.vertical) {
- this.currentY = event.clientY;
- diff = (this.startY - this.currentY) / this.$parent.sliderSize * 100;
+ childNodes.forEach(function (child) {
+ child.visible = filterNodeMethod.call(child, value, child.data, child);
+
+ traverse(child);
+ });
+
+ if (!node.visible && childNodes.length) {
+ var allHidden = true;
+
+ childNodes.forEach(function (child) {
+ if (child.visible) allHidden = false;
+ });
+
+ if (node.root) {
+ node.root.visible = allHidden === false;
} else {
- this.currentX = event.clientX;
- diff = (this.currentX - this.startX) / this.$parent.sliderSize * 100;
+ node.visible = allHidden === false;
}
- 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();
- _this.setPosition(_this.newPosition);
- }, 0);
- window.removeEventListener('mousemove', this.onDragging);
- window.removeEventListener('mouseup', this.onDragEnd);
- window.removeEventListener('contextmenu', this.onDragEnd);
- }
- },
- setPosition: function setPosition(newPosition) {
- if (newPosition === null) 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.$refs.tooltip && this.$refs.tooltip.updatePopper();
- if (!this.dragging && this.value !== this.oldValue) {
- this.oldValue = this.value;
- }
- }
- }
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ if (node.visible && !node.isLeaf) node.expand();
+ };
-/***/ },
-/* 258 */
-/***/ function(module, exports) {
+ traverse(this);
+ };
- module.exports={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),
- on: {
- "mouseenter": _vm.handleMouseEnter,
- "mouseleave": _vm.handleMouseLeave,
- "mousedown": _vm.onButtonDown
- }
- }, [_c('el-tooltip', {
- ref: "tooltip",
- attrs: {
- "placement": "top",
- "disabled": !_vm.showTooltip
+ TreeStore.prototype.setData = function setData(newVal) {
+ var instanceChanged = newVal !== this.root.data;
+ this.root.setData(newVal);
+ if (instanceChanged) {
+ this._initDefaultCheckedNodes();
}
- }, [_c('span', {
- slot: "content"
- }, [_vm._v(_vm._s(_vm.formatValue))]), _c('div', {
- staticClass: "el-slider__button",
- class: {
- 'hover': _vm.hovering, 'dragging': _vm.dragging
+ };
+
+ TreeStore.prototype.getNode = function getNode(data) {
+ var key = (typeof data === 'undefined' ? 'undefined' : _typeof(data)) !== 'object' ? data : (0, _util.getNodeKey)(this.key, data);
+ return this.nodesMap[key];
+ };
+
+ 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.removeChild(node);
}
- })])], 1)
- },staticRenderFns: []}
+ };
-/***/ },
-/* 259 */
-/***/ function(module, exports) {
+ TreeStore.prototype.append = function append(data, parentData) {
+ var parentNode = parentData ? this.getNode(parentData) : this.root;
- module.exports={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
+ if (parentNode) {
+ parentNode.insertChild({ data: data });
}
- }, [(_vm.showInput && !_vm.range) ? _c('el-input-number', {
- ref: "input",
- staticClass: "el-slider__input",
- attrs: {
- "step": _vm.step,
- "disabled": _vm.disabled,
- "controls": _vm.showInputControls,
- "min": _vm.min,
- "max": _vm.max,
- "debounce": _vm.debounce,
- "size": "small"
- },
- model: {
- value: (_vm.firstValue),
- callback: function($$v) {
- _vm.firstValue = $$v
- },
- expression: "firstValue"
+ };
+
+ 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);
}
- }) : _vm._e(), _c('div', {
- ref: "slider",
- staticClass: "el-slider__runway",
- class: {
- 'show-input': _vm.showInput, 'disabled': _vm.disabled
- },
- style: (_vm.runwayStyle),
- on: {
- "click": _vm.onSliderClick
+ };
+
+ TreeStore.prototype.setDefaultCheckedKey = function setDefaultCheckedKey(newVal) {
+ if (newVal !== this.defaultCheckedKeys) {
+ this.defaultCheckedKeys = newVal;
+ this._initDefaultCheckedNodes();
}
- }, [_c('div', {
- staticClass: "el-slider__bar",
- style: (_vm.barStyle)
- }), _c('slider-button', {
- ref: "button1",
- attrs: {
- "vertical": _vm.vertical
- },
- model: {
- value: (_vm.firstValue),
- callback: function($$v) {
- _vm.firstValue = $$v
- },
- expression: "firstValue"
- }
- }), (_vm.range) ? _c('slider-button', {
- ref: "button2",
- attrs: {
- "vertical": _vm.vertical
- },
- model: {
- value: (_vm.secondValue),
- callback: function($$v) {
- _vm.secondValue = $$v
- },
- expression: "secondValue"
- }
- }) : _vm._e(), _vm._l((_vm.stops), function(item) {
- return (_vm.showStops) ? _c('div', {
- staticClass: "el-slider__stop",
- style: (_vm.vertical ? {
- 'bottom': item + '%'
- } : {
- 'left': item + '%'
- })
- }) : _vm._e()
- })], 2)], 1)
- },staticRenderFns: []}
-
-/***/ },
-/* 260 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _directive = __webpack_require__(261);
-
- var _directive2 = _interopRequireDefault(_directive);
-
- var _index = __webpack_require__(265);
-
- var _index2 = _interopRequireDefault(_index);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = {
- install: function install(Vue) {
- Vue.use(_directive2.default);
- Vue.prototype.$loading = _index2.default;
- },
-
- directive: _directive2.default,
- service: _index2.default
- };
+ };
-/***/ },
-/* 261 */
-/***/ function(module, exports, __webpack_require__) {
+ TreeStore.prototype.registerNode = function registerNode(node) {
+ var key = this.key;
+ if (!key || !node || !node.data) return;
- 'use strict';
+ var nodeKey = node.key;
+ if (nodeKey !== undefined) this.nodesMap[node.key] = node;
+ };
- var _vue = __webpack_require__(133);
+ TreeStore.prototype.deregisterNode = function deregisterNode(node) {
+ var key = this.key;
+ if (!key || !node || !node.data) return;
- var _vue2 = _interopRequireDefault(_vue);
+ delete this.nodesMap[node.key];
+ };
- var _dom = __webpack_require__(44);
+ TreeStore.prototype.getCheckedNodes = function getCheckedNodes() {
+ var leafOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var checkedNodes = [];
+ var traverse = function traverse(node) {
+ var childNodes = node.root ? node.root.childNodes : node.childNodes;
- var Mask = _vue2.default.extend(__webpack_require__(262));
+ childNodes.forEach(function (child) {
+ if (!leafOnly && child.checked || leafOnly && child.isLeaf && child.checked) {
+ checkedNodes.push(child.data);
+ }
- exports.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 = (0, _dom.getStyle)(document.body, 'position');
- el.originalOverflow = (0, _dom.getStyle)(document.body, 'overflow');
+ traverse(child);
+ });
+ };
- (0, _dom.addClass)(el.mask, 'is-fullscreen');
- insertDom(document.body, el, binding);
- } else {
- (0, _dom.removeClass)(el.mask, 'is-fullscreen');
+ traverse(this);
- if (binding.modifiers.body) {
- el.originalPosition = (0, _dom.getStyle)(document.body, 'position');
+ return checkedNodes;
+ };
- ['top', 'left'].forEach(function (property) {
- var scroll = property === 'top' ? 'scrollTop' : 'scrollLeft';
- el.maskStyle[property] = el.getBoundingClientRect()[property] + document.body[scroll] + document.documentElement[scroll] + 'px';
- });
- ['height', 'width'].forEach(function (property) {
- el.maskStyle[property] = el.getBoundingClientRect()[property] + 'px';
- });
+ TreeStore.prototype.getCheckedKeys = function getCheckedKeys() {
+ var leafOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
- insertDom(document.body, el, binding);
- } else {
- el.originalPosition = (0, _dom.getStyle)(el, 'position');
- insertDom(el, el, binding);
- }
+ var key = this.key;
+ var allNodes = this._getAllNodes();
+ var keys = [];
+ allNodes.forEach(function (node) {
+ if (!leafOnly || leafOnly && node.isLeaf) {
+ if (node.checked) {
+ keys.push((node.data || {})[key]);
}
- });
- } else {
- if (el.domVisible) {
- el.instance.$on('after-leave', function (_) {
- el.domVisible = false;
- if (binding.modifiers.fullscreen && el.originalOverflow !== 'hidden') {
- document.body.style.overflow = el.originalOverflow;
- }
- if (binding.modifiers.fullscreen || binding.modifiers.body) {
- document.body.style.position = el.originalPosition;
- } else {
- el.style.position = el.originalPosition;
- }
- });
- el.instance.visible = false;
}
- }
+ });
+ return keys;
};
- var insertDom = function insertDom(parent, el, binding) {
- if (!el.domVisible && (0, _dom.getStyle)(el, 'display') !== 'none' && (0, _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') {
- parent.style.position = 'relative';
- }
- if (binding.modifiers.fullscreen && binding.modifiers.lock) {
- parent.style.overflow = 'hidden';
+ TreeStore.prototype._getAllNodes = function _getAllNodes() {
+ var allNodes = [];
+ var nodesMap = this.nodesMap;
+ for (var nodeKey in nodesMap) {
+ if (nodesMap.hasOwnProperty(nodeKey)) {
+ allNodes.push(nodesMap[nodeKey]);
}
- el.domVisible = true;
-
- parent.appendChild(el.mask);
- Vue.nextTick(function () {
- el.instance.visible = true;
- });
- el.domInserted = true;
}
+
+ return allNodes;
};
- Vue.directive('loading', {
- bind: function bind(el, binding) {
- var mask = new Mask({
- el: document.createElement('div'),
- data: {
- text: el.getAttribute('element-loading-text'),
- fullscreen: !!binding.modifiers.fullscreen
+ 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);
}
- });
- el.instance = mask;
- el.mask = mask.$el;
- el.maskStyle = {};
+ continue;
+ }
- toggleLoading(el, binding);
- },
+ var parent = node.parent;
+ while (parent && parent.level > 0) {
+ cache[parent.data[key]] = true;
+ parent = parent.parent;
+ }
- update: function update(el, binding) {
- el.instance.setText(el.getAttribute('element-loading-text'));
- if (binding.oldValue !== binding.value) {
- toggleLoading(el, binding);
+ if (node.isLeaf || this.checkStrictly) {
+ node.setChecked(true, false);
+ continue;
}
- },
+ node.setChecked(true, true);
- unbind: function unbind(el, binding) {
- if (el.domInserted) {
- if (binding.modifiers.fullscreen || binding.modifiers.body) {
- document.body.removeChild(el.mask);
- } else {
- el.mask && el.mask.parentNode && el.mask.parentNode.removeChild(el.mask);
- }
+ 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);
+ })();
}
}
- });
- };
+ };
-/***/ },
-/* 262 */
-/***/ function(module, exports, __webpack_require__) {
+ TreeStore.prototype.setCheckedNodes = function setCheckedNodes(array) {
+ var leafOnly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(263),
- /* template */
- __webpack_require__(264),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ var key = this.key;
+ var checkedKeys = {};
+ array.forEach(function (item) {
+ checkedKeys[(item || {})[key]] = true;
+ });
- module.exports = Component.exports
+ this._setCheckedKeys(key, leafOnly, checkedKeys);
+ };
+ TreeStore.prototype.setCheckedKeys = function setCheckedKeys(keys) {
+ var leafOnly = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
-/***/ },
-/* 263 */
-/***/ function(module, exports) {
+ this.defaultCheckedKeys = keys;
+ var key = this.key;
+ var checkedKeys = {};
+ keys.forEach(function (key) {
+ checkedKeys[key] = true;
+ });
- 'use strict';
+ this._setCheckedKeys(key, leafOnly, checkedKeys);
+ };
- exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ TreeStore.prototype.setDefaultExpandedKeys = function setDefaultExpandedKeys(keys) {
+ var _this3 = this;
- exports.default = {
- data: function data() {
- return {
- text: null,
- fullscreen: true,
- visible: false,
- customClass: ''
- };
- },
+ keys = keys || [];
+ this.defaultExpandedKeys = keys;
+
+ keys.forEach(function (key) {
+ var node = _this3.getNode(key);
+ if (node) node.expand(null, _this3.autoExpandParent);
+ });
+ };
+ TreeStore.prototype.setChecked = function setChecked(data, checked, deep) {
+ var node = this.getNode(data);
- methods: {
- handleAfterLeave: function handleAfterLeave() {
- this.$emit('after-leave');
- },
- setText: function setText(text) {
- this.text = text;
+ if (node) {
+ node.setChecked(!!checked, deep);
}
- }
- };
+ };
-/***/ },
-/* 264 */
-/***/ function(module, exports) {
+ TreeStore.prototype.getCurrentNode = function getCurrentNode() {
+ return this.currentNode;
+ };
- module.exports={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
- }]
- }, [_c('div', {
- staticClass: "el-loading-spinner"
- }, [_c('svg', {
- staticClass: "circular",
- attrs: {
- "viewBox": "25 25 50 50"
- }
- }, [_c('circle', {
- staticClass: "path",
- attrs: {
- "cx": "50",
- "cy": "50",
- "r": "20",
- "fill": "none"
+ TreeStore.prototype.setCurrentNode = function setCurrentNode(node) {
+ this.currentNode = node;
+ };
+
+ TreeStore.prototype.setCurrentNodeKey = function setCurrentNodeKey(key) {
+ var node = this.getNode(key);
+ if (node) {
+ this.currentNode = node;
}
- })]), (_vm.text) ? _c('p', {
- staticClass: "el-loading-text"
- }, [_vm._v(_vm._s(_vm.text))]) : _vm._e()])])])
- },staticRenderFns: []}
+ };
+
+ return TreeStore;
+ }();
+
+ exports.default = TreeStore;
+ ;
/***/ },
-/* 265 */
+/* 237 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
+ exports.getChildState = undefined;
- var _vue = __webpack_require__(133);
-
- var _vue2 = _interopRequireDefault(_vue);
-
- var _loading = __webpack_require__(262);
-
- var _loading2 = _interopRequireDefault(_loading);
-
- var _dom = __webpack_require__(44);
+ 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; }; }();
var _merge = __webpack_require__(64);
var _merge2 = _interopRequireDefault(_merge);
+ var _util = __webpack_require__(238);
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var LoadingConstructor = _vue2.default.extend(_loading2.default);
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
- var defaults = {
- text: null,
- fullscreen: true,
- body: false,
- lock: false,
- customClass: ''
+ var getChildState = exports.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 fullscreenLoading = void 0;
+ var reInitChecked = function reInitChecked(node) {
+ var _getChildState = getChildState(node.childNodes),
+ all = _getChildState.all,
+ none = _getChildState.none,
+ half = _getChildState.half;
- LoadingConstructor.prototype.originalPosition = '';
- LoadingConstructor.prototype.originalOverflow = '';
+ 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;
+ }
- LoadingConstructor.prototype.close = function () {
- var _this = this;
+ var parent = node.parent;
+ if (!parent || parent.level === 0) return;
- if (this.fullscreen && this.originalOverflow !== 'hidden') {
- document.body.style.overflow = this.originalOverflow;
- }
- if (this.fullscreen || this.body) {
- document.body.style.position = this.originalPosition;
- } else {
- this.target.style.position = this.originalPosition;
- }
- if (this.fullscreen) {
- fullscreenLoading = undefined;
+ if (!node.store.checkStrictly) {
+ reInitChecked(parent);
}
- this.$on('after-leave', function (_) {
- _this.$el && _this.$el.parentNode && _this.$el.parentNode.removeChild(_this.$el);
- _this.$destroy();
- });
- this.visible = false;
};
- var addStyle = function addStyle(options, parent, instance) {
- var maskStyle = {};
- if (options.fullscreen) {
- instance.originalPosition = (0, _dom.getStyle)(document.body, 'position');
- instance.originalOverflow = (0, _dom.getStyle)(document.body, 'overflow');
- } else if (options.body) {
- instance.originalPosition = (0, _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 = (0, _dom.getStyle)(parent, 'position');
+ var initLazyLoadChild = function initLazyLoadChild(node) {
+ var childNodes = node.childNodes;
+ if (node.checked) {
+ for (var i = 0, j = childNodes.length; i < j; i++) {
+ var child = childNodes[i];
+ if (!child.disabled) {
+ child.checked = true;
+ }
+ }
}
- Object.keys(maskStyle).forEach(function (property) {
- instance.$el.style[property] = maskStyle[property];
- });
+
+ var parent = node.parent;
+ if (!parent || parent.level === 0) return;
+ reInitChecked(parent);
};
- var Loading = function Loading() {
- var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
+ var getPropertyFromData = function getPropertyFromData(node, prop) {
+ var props = node.store.props;
+ var data = node.data || {};
+ var config = props[prop];
- if (_vue2.default.prototype.$isServer) return;
- options = (0, _merge2.default)({}, 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
- });
-
- addStyle(options, parent, instance);
- if (instance.originalPosition !== 'absolute' && instance.originalPosition !== 'fixed') {
- parent.style.position = 'relative';
- }
- if (options.fullscreen && options.lock) {
- parent.style.overflow = 'hidden';
- }
- parent.appendChild(instance.$el);
- _vue2.default.nextTick(function () {
- instance.visible = true;
- });
- if (options.fullscreen) {
- fullscreenLoading = instance;
+ if (typeof config === 'function') {
+ return config(data, node);
+ } else if (typeof config === 'string') {
+ return data[config];
+ } else if (typeof config === 'undefined') {
+ return '';
}
- return instance;
};
- exports.default = Loading;
-
-/***/ },
-/* 266 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _icon = __webpack_require__(267);
+ var nodeIdSeed = 0;
- var _icon2 = _interopRequireDefault(_icon);
+ var Node = function () {
+ function Node(options) {
+ _classCallCheck(this, Node);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ this.id = nodeIdSeed++;
+ this.text = null;
+ this.checked = false;
+ this.indeterminate = false;
+ this.data = null;
+ this.expanded = false;
+ this.parent = null;
+ this.visible = true;
- /* istanbul ignore next */
- _icon2.default.install = function (Vue) {
- Vue.component(_icon2.default.name, _icon2.default);
- };
+ for (var name in options) {
+ if (options.hasOwnProperty(name)) {
+ this[name] = options[name];
+ }
+ }
- exports.default = _icon2.default;
+ // internal
+ this.level = 0;
+ this.loaded = false;
+ this.childNodes = [];
+ this.loading = false;
-/***/ },
-/* 267 */
-/***/ function(module, exports, __webpack_require__) {
+ if (this.parent) {
+ this.level = this.parent.level + 1;
+ }
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(268),
- /* template */
- __webpack_require__(269),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ var store = this.store;
+ if (!store) {
+ throw new Error('[Node]store is required!');
+ }
+ store.registerNode(this);
- module.exports = Component.exports
+ 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);
-/***/ },
-/* 268 */
-/***/ function(module, exports) {
+ if (store.defaultExpandAll) {
+ this.expanded = true;
+ }
+ } else if (this.level > 0 && store.lazy && store.defaultExpandAll) {
+ this.expand();
+ }
- 'use strict';
+ 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);
+ }
- exports.__esModule = true;
- //
- //
- //
- //
+ if (key && store.currentNodeKey && this.key === store.currentNodeKey) {
+ store.currentNode = this;
+ }
- exports.default = {
- name: 'ElIcon',
+ if (store.lazy) {
+ store._initDefaultCheckedNode(this);
+ }
- props: {
- name: String
+ this.updateLeafState();
}
- };
-/***/ },
-/* 269 */
-/***/ function(module, exports) {
+ Node.prototype.setData = function setData(data) {
+ if (!Array.isArray(data)) {
+ (0, _util.markNodeData)(this, data);
+ }
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('i', {
- class: 'el-icon-' + _vm.name
- })
- },staticRenderFns: []}
+ this.data = data;
+ this.childNodes = [];
-/***/ },
-/* 270 */
-/***/ function(module, exports, __webpack_require__) {
+ var children = void 0;
+ if (this.level === 0 && this.data instanceof Array) {
+ children = this.data;
+ } else {
+ children = getPropertyFromData(this, 'children') || [];
+ }
- 'use strict';
+ for (var i = 0, j = children.length; i < j; i++) {
+ this.insertChild({ data: children[i] });
+ }
+ };
- exports.__esModule = true;
+ Node.prototype.insertChild = function insertChild(child, index) {
+ if (!child) throw new Error('insertChild error: child is required.');
- var _row = __webpack_require__(271);
+ if (!(child instanceof Node)) {
+ (0, _merge2.default)(child, {
+ parent: this,
+ store: this.store
+ });
+ child = new Node(child);
+ }
- var _row2 = _interopRequireDefault(_row);
+ child.level = this.level + 1;
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ if (typeof index === 'undefined' || index < 0) {
+ this.childNodes.push(child);
+ } else {
+ this.childNodes.splice(index, 0, child);
+ }
- /* istanbul ignore next */
- _row2.default.install = function (Vue) {
- Vue.component(_row2.default.name, _row2.default);
- };
+ this.updateLeafState();
+ };
- exports.default = _row2.default;
+ Node.prototype.insertBefore = function insertBefore(child, ref) {
+ var index = void 0;
+ if (ref) {
+ index = this.childNodes.indexOf(ref);
+ }
+ this.insertChild(child, index);
+ };
-/***/ },
-/* 271 */
-/***/ function(module, exports) {
+ 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);
+ };
- 'use strict';
+ Node.prototype.removeChild = function removeChild(child) {
+ var index = this.childNodes.indexOf(child);
- exports.__esModule = true;
- exports.default = {
- name: 'ElRow',
+ if (index > -1) {
+ this.store && this.store.deregisterNode(child);
+ child.parent = null;
+ this.childNodes.splice(index, 1);
+ }
- componentName: 'ElRow',
+ this.updateLeafState();
+ };
- props: {
- tag: {
- type: String,
- default: 'div'
- },
- gutter: Number,
- type: String,
- justify: {
- type: String,
- default: 'start'
- },
- align: {
- type: String,
- default: 'top'
+ Node.prototype.removeChildByData = function removeChildByData(data) {
+ var targetNode = null;
+ this.childNodes.forEach(function (node) {
+ if (node.data === data) {
+ targetNode = node;
+ }
+ });
+
+ if (targetNode) {
+ this.removeChild(targetNode);
}
- },
+ };
- computed: {
- style: function style() {
- var ret = {};
+ Node.prototype.expand = function expand(callback, expandParent) {
+ var _this = this;
- if (this.gutter) {
- ret.marginLeft = '-' + this.gutter / 2 + 'px';
- ret.marginRight = ret.marginLeft;
+ 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();
+ };
- return ret;
+ if (this.shouldLoadData()) {
+ this.loadData(function (data) {
+ if (data instanceof Array) {
+ initLazyLoadChild(_this);
+ done();
+ }
+ });
+ } else {
+ done();
}
- },
+ };
- 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);
- }
- };
+ Node.prototype.doCreateChildren = function doCreateChildren(array) {
+ var _this2 = this;
-/***/ },
-/* 272 */
-/***/ function(module, exports, __webpack_require__) {
+ var defaultProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
- 'use strict';
+ array.forEach(function (item) {
+ _this2.insertChild((0, _merge2.default)({ data: item }, defaultProps));
+ });
+ };
- exports.__esModule = true;
+ Node.prototype.collapse = function collapse() {
+ this.expanded = false;
+ };
- var _col = __webpack_require__(273);
+ Node.prototype.shouldLoadData = function shouldLoadData() {
+ return this.store.lazy === true && this.store.load && !this.loaded;
+ };
- var _col2 = _interopRequireDefault(_col);
+ 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;
+ };
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ Node.prototype.setChecked = function setChecked(value, deep, recursion, passValue) {
+ var _this3 = this;
- /* istanbul ignore next */
- _col2.default.install = function (Vue) {
- Vue.component(_col2.default.name, _col2.default);
- };
+ this.indeterminate = value === 'half';
+ this.checked = value === true;
- exports.default = _col2.default;
+ var _getChildState2 = getChildState(this.childNodes),
+ all = _getChildState2.all,
+ allWithoutDisable = _getChildState2.allWithoutDisable;
-/***/ },
-/* 273 */
-/***/ function(module, exports) {
+ if (this.childNodes.length && !all && allWithoutDisable) {
+ this.checked = false;
+ value = false;
+ }
- 'use strict';
+ var handleDescendants = function handleDescendants(lazy) {
+ if (deep && !lazy) {
+ 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);
+ }
- exports.__esModule = true;
+ var _getChildState3 = getChildState(childNodes),
+ half = _getChildState3.half,
+ _all = _getChildState3.all;
- 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; };
+ if (!_all) {
+ _this3.checked = _all;
+ _this3.indeterminate = half;
+ }
+ }
+ };
- exports.default = {
- name: 'ElCol',
+ if (!this.store.checkStrictly && this.shouldLoadData()) {
+ // Only work on lazy load data.
+ this.loadData(function () {
+ handleDescendants(true);
+ }, {
+ checked: value !== false
+ });
+ } else {
+ handleDescendants();
+ }
- 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]
- },
+ var parent = this.parent;
+ if (!parent || parent.level === 0) return;
- computed: {
- gutter: function gutter() {
- var parent = this.$parent;
- while (parent && parent.$options.componentName !== 'ElRow') {
- parent = parent.$parent;
- }
- return parent ? parent.gutter : 0;
+ if (!this.store.checkStrictly && !recursion) {
+ reInitChecked(parent);
}
- },
- render: function render(h) {
- var _this = this;
+ };
- var classList = [];
- var style = {};
+ Node.prototype.getChildren = function getChildren() {
+ // this is data
+ var data = this.data;
+ if (!data) return null;
- if (this.gutter) {
- style.paddingLeft = this.gutter / 2 + 'px';
- style.paddingRight = style.paddingLeft;
+ var props = this.store.props;
+ var children = 'children';
+ if (props) {
+ children = props.children || 'children';
}
- ['span', 'offset', 'pull', 'push'].forEach(function (prop) {
- if (_this[prop]) {
- classList.push(prop !== 'span' ? 'el-col-' + prop + '-' + _this[prop] : 'el-col-' + _this[prop]);
- }
+ if (data[children] === undefined) {
+ data[children] = null;
+ }
+
+ 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;
});
- ['xs', 'sm', 'md', 'lg'].forEach(function (size) {
- if (typeof _this[size] === 'number') {
- classList.push('el-col-' + size + '-' + _this[size]);
- } else if (_typeof(_this[size]) === 'object') {
- (function () {
- 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]);
- });
- })();
+ var newDataMap = {};
+ var newNodes = [];
+
+ newData.forEach(function (item, index) {
+ if (item[_util.NODE_KEY]) {
+ newDataMap[item[_util.NODE_KEY]] = { index: index, data: item };
+ } else {
+ newNodes.push({ index: index, data: item });
}
});
- return h(this.tag, {
- class: ['el-col', classList],
- style: style
- }, this.$slots.default);
- }
- };
+ oldData.forEach(function (item) {
+ if (!newDataMap[item[_util.NODE_KEY]]) _this4.removeChildByData(item);
+ });
-/***/ },
-/* 274 */
-/***/ function(module, exports, __webpack_require__) {
+ newNodes.forEach(function (_ref) {
+ var index = _ref.index,
+ data = _ref.data;
- 'use strict';
+ _this4.insertChild({ data: data }, index);
+ });
- exports.__esModule = true;
+ this.updateLeafState();
+ };
- var _src = __webpack_require__(275);
+ Node.prototype.loadData = function loadData(callback) {
+ var _this5 = this;
- var _src2 = _interopRequireDefault(_src);
+ var defaultProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ if (this.store.lazy === true && this.store.load && !this.loaded && (!this.loading || Object.keys(defaultProps).length)) {
+ this.loading = true;
- /* istanbul ignore next */
- _src2.default.install = function (Vue) {
- Vue.component(_src2.default.name, _src2.default);
- };
+ var resolve = function resolve(children) {
+ _this5.loaded = true;
+ _this5.loading = false;
+ _this5.childNodes = [];
- exports.default = _src2.default;
+ _this5.doCreateChildren(children, defaultProps);
-/***/ },
-/* 275 */
-/***/ function(module, exports, __webpack_require__) {
+ _this5.updateLeafState();
+ if (callback) {
+ callback.call(_this5, children);
+ }
+ };
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(276),
- /* template */
- null,
- /* styles */
+ this.store.load(this, resolve);
+ } else {
+ if (callback) {
+ callback.call(this);
+ }
+ }
+ };
+
+ _createClass(Node, [{
+ key: 'label',
+ get: function get() {
+ return getPropertyFromData(this, 'label');
+ }
+ }, {
+ key: 'icon',
+ get: function get() {
+ return getPropertyFromData(this, 'icon');
+ }
+ }, {
+ 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');
+ }
+ }]);
+
+ return Node;
+ }();
+
+ exports.default = Node;
+
+/***/ },
+/* 238 */
+/***/ function(module, exports) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+ var NODE_KEY = exports.NODE_KEY = '$treeNodeId';
+
+ var markNodeData = exports.markNodeData = function markNodeData(node, data) {
+ if (data[NODE_KEY]) return;
+ Object.defineProperty(data, NODE_KEY, {
+ value: node.id,
+ enumerable: false,
+ configurable: false,
+ writable: false
+ });
+ };
+
+ var getNodeKey = exports.getNodeKey = function getNodeKey(key, data) {
+ if (!key) return data[NODE_KEY];
+ return data[key];
+ };
+
+/***/ },
+/* 239 */
+/***/ function(module, exports, __webpack_require__) {
+
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(240),
+ /* template */
+ __webpack_require__(241),
+ /* styles */
null,
/* scopeId */
null,
@@ -54974,348 +54212,177 @@ module.exports =
/***/ },
-/* 276 */
+/* 240 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _uploadList = __webpack_require__(277);
-
- var _uploadList2 = _interopRequireDefault(_uploadList);
-
- var _upload = __webpack_require__(281);
-
- var _upload2 = _interopRequireDefault(_upload);
-
- var _iframeUpload = __webpack_require__(287);
+ var _collapseTransition = __webpack_require__(49);
- var _iframeUpload2 = _interopRequireDefault(_iframeUpload);
+ var _collapseTransition2 = _interopRequireDefault(_collapseTransition);
- var _progress = __webpack_require__(279);
+ var _checkbox = __webpack_require__(130);
- var _progress2 = _interopRequireDefault(_progress);
+ var _checkbox2 = _interopRequireDefault(_checkbox);
- var _migrating = __webpack_require__(289);
+ var _emitter = __webpack_require__(15);
- var _migrating2 = _interopRequireDefault(_migrating);
+ var _emitter2 = _interopRequireDefault(_emitter);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- function noop() {}
-
exports.default = {
- name: 'ElUpload',
-
- mixins: [_migrating2.default],
+ name: 'ElTreeNode',
- components: {
- ElProgress: _progress2.default,
- UploadList: _uploadList2.default,
- Upload: _upload2.default,
- IframeUpload: _iframeUpload2.default
- },
+ componentName: 'ElTreeNode',
- provide: {
- uploader: undefined
- },
+ mixins: [_emitter2.default],
props: {
- action: {
- type: String,
- required: true
- },
- headers: {
- type: Object,
+ node: {
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,
- onRemove: {
- type: Function,
- default: noop
- },
- onChange: {
- type: Function,
- default: noop
- },
- onPreview: {
- type: Function
- },
- onSuccess: {
- type: Function,
- default: noop
- },
- onProgress: {
- type: Function,
- default: noop
- },
- onError: {
- type: Function,
- default: noop
- },
- fileList: {
- type: Array,
- default: function _default() {
- return [];
+ props: {},
+ renderContent: Function
+ },
+
+ components: {
+ ElCollapseTransition: _collapseTransition2.default,
+ ElCheckbox: _checkbox2.default,
+ NodeContent: {
+ props: {
+ node: {
+ required: true
+ }
+ },
+ render: function render(h) {
+ var parent = this.$parent;
+ var node = this.node;
+ var data = node.data;
+ var store = node.store;
+ return parent.renderContent ? parent.renderContent.call(parent._renderProxy, h, { _self: parent.tree.$vnode.context, node: node, data: data, store: store }) : h(
+ 'span',
+ { 'class': 'el-tree-node__label' },
+ [this.node.label]
+ );
}
- },
- autoUpload: {
- type: Boolean,
- default: true
- },
- listType: {
- type: String,
- default: 'text' // text,picture,picture-card
- },
- httpRequest: Function,
- disabled: Boolean
+ }
},
data: function data() {
return {
- uploadFiles: [],
- dragOver: false,
- draging: false,
- tempIndex: 1
+ tree: null,
+ expanded: false,
+ childNodeRendered: false,
+ showCheckbox: false,
+ oldChecked: null,
+ oldIndeterminate: null
};
},
watch: {
- 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 = 'success';
- return item;
- });
+ '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) {
+ this.expanded = val;
+ if (val) {
+ this.childNodeRendered = true;
}
}
},
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
- };
-
- try {
- file.url = URL.createObjectURL(rawFile);
- } catch (err) {
- console.error(err);
- return;
+ getNodeKey: function getNodeKey(node, index) {
+ var nodeKey = this.tree.nodeKey;
+ if (nodeKey && node) {
+ return node.data[nodeKey];
}
-
- 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;
+ return index;
},
- 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);
+ 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;
},
- 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) {
- if (raw) {
- file = this.getFile(raw);
+ 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();
}
- this.abort(file);
- var fileList = this.uploadFiles;
- fileList.splice(fileList.indexOf(file), 1);
- this.onRemove(file, fileList);
- },
- getFile: function getFile(rawFile) {
- var fileList = this.uploadFiles;
- var target;
- 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);
+ this.tree.$emit('node-click', this.node.data, this.node, this);
},
- clearFiles: function clearFiles() {
- this.uploadFiles = [];
+ 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);
+ }
},
- submit: function submit() {
- var _this2 = this;
-
- this.uploadFiles.filter(function (file) {
- return file.status === 'ready';
- }).forEach(function (file) {
- _this2.$refs['upload-inner'].upload(file.raw);
- });
+ handleCheckChange: function handleCheckChange(ev) {
+ this.node.setChecked(ev.target.checked, !this.tree.checkStrictly);
},
- 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'
- }
- };
+ handleChildNodeExpand: function handleChildNodeExpand(nodeData, node, instance) {
+ this.broadcast('ElTreeNode', 'tree-node-expand', node);
+ this.tree.$emit('node-expand', nodeData, node, instance);
}
},
- render: function render(h) {
- var uploadList;
+ created: function created() {
+ var _this = this;
- if (this.showFileList) {
- uploadList = h(
- _uploadList2.default,
- {
- attrs: {
- disabled: this.disabled,
- listType: this.listType,
- files: this.uploadFiles,
+ var parent = this.$parent;
- handlePreview: this.onPreview },
- on: {
- 'remove': this.handleRemove
- }
- },
- []
- );
+ if (parent.isTree) {
+ this.tree = parent;
+ } else {
+ this.tree = parent.tree;
}
- 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.disabled,
- '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 = typeof FormData !== 'undefined' || this.$isServer ? h(
- 'upload',
- uploadData,
- [trigger]
- ) : h(
- 'iframeUpload',
- uploadData,
- [trigger]
- );
-
- return h(
- 'div',
- null,
- [this.listType === 'picture-card' ? uploadList : '', this.$slots.trigger ? [uploadComponent, this.$slots.default] : uploadComponent, this.$slots.tip, this.listType !== 'picture-card' ? uploadList : '']
- );
- }
- };
-
-/***/ },
-/* 277 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(278),
- /* template */
- __webpack_require__(280),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
-
-/***/ },
-/* 278 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _locale = __webpack_require__(10);
+ var tree = this.tree;
+ if (!tree) {
+ console.warn('Can not find node\'s tree.');
+ }
- var _locale2 = _interopRequireDefault(_locale);
+ var props = tree.props || {};
+ var childrenKey = props['children'] || 'children';
- var _progress = __webpack_require__(279);
+ this.$watch('node.data.' + childrenKey, function () {
+ _this.node.updateChildren();
+ });
- var _progress2 = _interopRequireDefault(_progress);
+ this.showCheckbox = tree.showCheckbox;
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ if (this.node.expanded) {
+ this.expanded = true;
+ this.childNodeRendered = true;
+ }
+ if (this.tree.accordion) {
+ this.$on('tree-node-expand', function (node) {
+ if (_this.node !== node) {
+ _this.node.collapse();
+ }
+ });
+ }
+ }
+ }; //
//
//
//
@@ -55361,142 +54428,154 @@ module.exports =
//
//
//
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
-
- exports.default = {
- mixins: [_locale2.default],
-
- components: { ElProgress: _progress2.default },
-
- 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);
- }
- }
- };
/***/ },
-/* 279 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(77);
-
-/***/ },
-/* 280 */
+/* 241 */
/***/ function(module, exports) {
module.exports={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
+ return _c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.node.visible),
+ expression: "node.visible"
+ }],
+ staticClass: "el-tree-node",
+ class: {
+ 'is-expanded': _vm.childNodeRendered && _vm.expanded,
+ 'is-current': _vm.tree.store.currentNode === _vm.node,
+ 'is-hidden': !_vm.node.visible
+ },
+ on: {
+ "click": function($event) {
+ $event.stopPropagation();
+ _vm.handleClick($event)
}
- ],
- attrs: {
- "tag": "ul",
- "name": "el-list"
}
- }, _vm._l((_vm.files), function(file, index) {
- return _c('li', {
- key: index,
- class: ['el-upload-list__item', 'is-' + file.status]
- }, [(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
+ }, [_c('div', {
+ staticClass: "el-tree-node__content",
+ style: ({
+ 'padding-left': (_vm.node.level - 1) * _vm.tree.indent + 'px'
+ })
+ }, [_c('span', {
+ staticClass: "el-tree-node__expand-icon",
+ class: {
+ 'is-leaf': _vm.node.isLeaf, expanded: !_vm.node.isLeaf && _vm.expanded
+ },
+ on: {
+ "click": function($event) {
+ $event.stopPropagation();
+ _vm.handleExpandIconClick($event)
}
- })]), (!_vm.disabled) ? _c('i', {
- staticClass: "el-icon-close",
- on: {
- "click": function($event) {
- _vm.$emit('remove', file)
- }
+ }
+ }), (_vm.showCheckbox) ? _c('el-checkbox', {
+ attrs: {
+ "indeterminate": _vm.node.indeterminate,
+ "disabled": !!_vm.node.disabled
+ },
+ on: {
+ "change": _vm.handleCheckChange
+ },
+ nativeOn: {
+ "click": function($event) {
+ $event.stopPropagation();
}
- }) : _vm._e(), (file.status === 'uploading') ? _c('el-progress', {
+ },
+ model: {
+ value: (_vm.node.checked),
+ callback: function($$v) {
+ _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', [_c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.expanded),
+ expression: "expanded"
+ }],
+ staticClass: "el-tree-node__children"
+ }, _vm._l((_vm.node.childNodes), function(child) {
+ return _c('el-tree-node', {
+ key: _vm.getNodeKey(child),
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",
+ "render-content": _vm.renderContent,
+ "node": child
+ },
on: {
- "click": function($event) {
- _vm.handlePreview(file)
- }
+ "node-expand": _vm.handleChildNodeExpand
}
- }, [_c('i', {
- staticClass: "el-icon-view"
- })]) : _vm._e(), (!_vm.disabled) ? _c('span', {
- staticClass: "el-upload-list__item-delete",
+ })
+ }))])], 1)
+ },staticRenderFns: []}
+
+/***/ },
+/* 242 */
+/***/ function(module, exports) {
+
+ module.exports={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
+ }
+ }, [_vm._l((_vm.root.childNodes), function(child) {
+ return _c('el-tree-node', {
+ key: _vm.getNodeKey(child),
+ attrs: {
+ "node": child,
+ "props": _vm.props,
+ "render-content": _vm.renderContent
+ },
on: {
- "click": function($event) {
- _vm.$emit('remove', file)
- }
+ "node-expand": _vm.handleNodeExpand
}
- }, [_c('i', {
- staticClass: "el-icon-delete2"
- })]) : _vm._e()]) : _vm._e()], 1)
- }))
+ })
+ }), (!_vm.root.childNodes || _vm.root.childNodes.length === 0) ? _c('div', {
+ staticClass: "el-tree__empty-block"
+ }, [_c('span', {
+ staticClass: "el-tree__empty-text"
+ }, [_vm._v(_vm._s(_vm.emptyText))])]) : _vm._e()], 2)
},staticRenderFns: []}
/***/ },
-/* 281 */
+/* 243 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _main = __webpack_require__(244);
+
+ var _main2 = _interopRequireDefault(_main);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _main2.default.install = function (Vue) {
+ Vue.component(_main2.default.name, _main2.default);
+ };
+
+ exports.default = _main2.default;
+
+/***/ },
+/* 244 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(282),
+ __webpack_require__(245),
/* template */
- null,
+ __webpack_require__(246),
/* styles */
null,
/* scopeId */
@@ -55509,330 +54588,262 @@ module.exports =
/***/ },
-/* 282 */
-/***/ function(module, exports, __webpack_require__) {
+/* 245 */
+/***/ function(module, exports) {
'use strict';
exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var _ajax = __webpack_require__(283);
-
- var _ajax2 = _interopRequireDefault(_ajax);
-
- var _uploadDragger = __webpack_require__(284);
-
- var _uploadDragger2 = _interopRequireDefault(_uploadDragger);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
+ var TYPE_CLASSES_MAP = {
+ 'success': 'el-icon-circle-check',
+ 'warning': 'el-icon-warning',
+ 'error': 'el-icon-circle-cross'
+ };
exports.default = {
- inject: ['uploader'],
- components: {
- UploadDragger: _uploadDragger2.default
- },
+ name: 'ElAlert',
+
props: {
- type: String,
- action: {
+ title: {
type: String,
+ default: '',
required: true
},
- name: {
+ description: {
type: String,
- default: 'file'
+ default: ''
},
- 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() {}
+ type: {
+ type: String,
+ default: 'info'
},
- onRemove: {
- type: Function,
- default: function _default() {}
+ closable: {
+ type: Boolean,
+ default: true
},
- fileList: Array,
- autoUpload: Boolean,
- listType: String,
- httpRequest: {
- type: Function,
- default: _ajax2.default
+ closeText: {
+ type: String,
+ default: ''
},
- disabled: Boolean
+ showIcon: {
+ type: Boolean,
+ default: false
+ }
},
data: function data() {
return {
- mouseover: false,
- reqs: {}
+ visible: true
};
},
methods: {
- isImage: function isImage(str) {
- return str.indexOf('image') !== -1;
- },
- handleChange: function handleChange(ev) {
- var files = ev.target.files;
+ close: function close() {
+ this.visible = false;
+ this.$emit('close');
+ }
+ },
- if (!files) return;
- this.uploadFiles(files);
+ computed: {
+ typeClass: function typeClass() {
+ return 'el-alert--' + this.type;
},
- uploadFiles: function uploadFiles(files) {
- var _this = this;
-
- 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);
- });
+ iconClass: function iconClass() {
+ return TYPE_CLASSES_MAP[this.type] || 'el-icon-information';
},
- upload: function upload(rawFile, file) {
- var _this2 = this;
+ isBigIcon: function isBigIcon() {
+ return this.description || this.$slots.default ? 'is-big' : '';
+ },
+ isBoldTitle: function isBoldTitle() {
+ return this.description || this.$slots.default ? 'is-bold' : '';
+ }
+ }
+ };
- this.$refs.input.value = null;
+/***/ },
+/* 246 */
+/***/ function(module, exports) {
- if (!this.beforeUpload) {
- return this.post(rawFile);
+ module.exports={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.showIcon) ? _c('i', {
+ staticClass: "el-alert__icon",
+ class: [_vm.iconClass, _vm.isBigIcon]
+ }) : _vm._e(), _c('div', {
+ staticClass: "el-alert__content"
+ }, [(_vm.title) ? _c('span', {
+ staticClass: "el-alert__title",
+ class: [_vm.isBoldTitle]
+ }, [_vm._v(_vm._s(_vm.title))]) : _vm._e(), _vm._t("default", [(_vm.description) ? _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))])], 2)])])
+ },staticRenderFns: []}
- var before = this.beforeUpload(rawFile);
- if (before && before.then) {
- before.then(function (processedFile) {
- if (Object.prototype.toString.call(processedFile) === '[object File]') {
- _this2.post(processedFile);
- } else {
- _this2.post(rawFile);
- }
- }, function () {
- _this2.onRemove(rawFile, true);
- });
- } else if (before !== false) {
- this.post(rawFile);
- } else {
- this.onRemove(rawFile, true);
- }
- },
- abort: function abort(file) {
- var reqs = this.reqs;
+/***/ },
+/* 247 */
+/***/ function(module, exports, __webpack_require__) {
- 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;
+ 'use strict';
- var uid = rawFile.uid;
+ exports.__esModule = true;
- 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();
- }
- }
- },
+ var _main = __webpack_require__(248);
- 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;
+ var _main2 = _interopRequireDefault(_main);
- var data = {
- class: {
- 'el-upload': true
- },
- on: {
- click: handleClick
- }
- };
- data.class['el-upload--' + listType] = true;
- return h(
- 'div',
- data,
- [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
- }
- },
- []
- )]
- );
- }
- };
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ exports.default = _main2.default;
/***/ },
-/* 283 */
-/***/ function(module, exports) {
+/* 248 */
+/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- exports.default = upload;
- function getError(action, option, xhr) {
- var msg = void 0;
- if (xhr.response) {
- msg = xhr.status + ' ' + (xhr.response.error || xhr.response);
- } else if (xhr.responseText) {
- msg = xhr.status + ' ' + 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;
- }
+ var _vue = __webpack_require__(133);
- try {
- return JSON.parse(text);
- } catch (e) {
- return text;
- }
- }
+ var _vue2 = _interopRequireDefault(_vue);
- function upload(option) {
- if (typeof XMLHttpRequest === 'undefined') {
- return;
- }
+ var _popup = __webpack_require__(14);
- var xhr = new XMLHttpRequest();
- var action = option.action;
+ var _vdom = __webpack_require__(194);
- if (xhr.upload) {
- xhr.upload.onprogress = function progress(e) {
- if (e.total > 0) {
- e.percent = e.loaded / e.total * 100;
- }
- option.onProgress(e);
- };
- }
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var formData = new FormData();
+ var NotificationConstructor = _vue2.default.extend(__webpack_require__(249));
- if (option.data) {
- Object.keys(option.data).map(function (key) {
- formData.append(key, option.data[key]);
- });
- }
+ var instance = void 0;
+ var instances = [];
+ var seed = 1;
- formData.append(option.filename, option.file);
+ var Notification = function Notification(options) {
+ if (_vue2.default.prototype.$isServer) return;
+ options = options || {};
+ var userOnClose = options.onClose;
+ var id = 'notification_' + seed++;
- xhr.onerror = function error(e) {
- option.onError(e);
+ options.onClose = function () {
+ Notification.close(id, userOnClose);
};
- xhr.onload = function onload() {
- if (xhr.status < 200 || xhr.status >= 300) {
- return option.onError(getError(action, option, xhr));
- }
-
- option.onSuccess(getBody(xhr));
- };
+ instance = new NotificationConstructor({
+ data: options
+ });
- xhr.open('post', action, true);
+ if ((0, _vdom.isVNode)(options.message)) {
+ instance.$slots.default = [options.message];
+ options.message = '';
+ }
+ instance.id = id;
+ instance.vm = instance.$mount();
+ document.body.appendChild(instance.vm.$el);
+ instance.vm.visible = true;
+ instance.dom = instance.vm.$el;
+ instance.dom.style.zIndex = _popup.PopupManager.nextZIndex();
- if (option.withCredentials && 'withCredentials' in xhr) {
- xhr.withCredentials = true;
+ var offset = options.offset || 0;
+ var topDist = offset;
+ for (var i = 0, len = instances.length; i < len; i++) {
+ topDist += instances[i].$el.offsetHeight + 16;
}
+ topDist += 16;
+ instance.top = topDist;
+ instances.push(instance);
+ return instance.vm;
+ };
- var headers = option.headers || {};
+ ['success', 'warning', 'info', 'error'].forEach(function (type) {
+ Notification[type] = function (options) {
+ if (typeof options === 'string' || (0, _vdom.isVNode)(options)) {
+ options = {
+ message: options
+ };
+ }
+ options.type = type;
+ return Notification(options);
+ };
+ });
- for (var item in headers) {
- if (headers.hasOwnProperty(item) && headers[item] !== null) {
- xhr.setRequestHeader(item, headers[item]);
+ Notification.close = function (id, userOnClose) {
+ var index = void 0;
+ var removedHeight = void 0;
+ for (var i = 0, len = instances.length; i < len; i++) {
+ if (id === instances[i].id) {
+ if (typeof userOnClose === 'function') {
+ userOnClose(instances[i]);
+ }
+ index = i;
+ removedHeight = instances[i].dom.offsetHeight;
+ instances.splice(i, 1);
+ break;
}
}
- xhr.send(formData);
- return xhr;
- }
+
+ if (len > 1) {
+ for (i = index; i < len - 1; i++) {
+ instances[i].dom.style.top = parseInt(instances[i].dom.style.top, 10) - removedHeight - 16 + 'px';
+ }
+ }
+ };
+
+ exports.default = Notification;
/***/ },
-/* 284 */
+/* 249 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(285),
+ __webpack_require__(250),
/* template */
- __webpack_require__(286),
+ __webpack_require__(251),
/* styles */
null,
/* scopeId */
@@ -55845,7 +54856,7 @@ module.exports =
/***/ },
-/* 285 */
+/* 250 */
/***/ function(module, exports) {
'use strict';
@@ -55864,69 +54875,191 @@ module.exports =
//
//
//
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+ var typeMap = {
+ success: 'circle-check',
+ info: 'information',
+ warning: 'warning',
+ error: 'circle-cross'
+ };
exports.default = {
- name: 'ElUploadDrag',
- props: {
- disabled: Boolean
- },
data: function data() {
return {
- dragover: false
+ visible: false,
+ title: '',
+ message: '',
+ duration: 4500,
+ type: '',
+ customClass: '',
+ iconClass: '',
+ onClose: null,
+ onClick: null,
+ closed: false,
+ top: null,
+ timer: null
};
},
+
+ computed: {
+ typeClass: function typeClass() {
+ return this.type && typeMap[this.type] ? 'el-icon-' + typeMap[this.type] : '';
+ }
+ },
+
+ watch: {
+ closed: function closed(newVal) {
+ if (newVal) {
+ this.visible = false;
+ this.$el.addEventListener('transitionend', this.destroyElement);
+ }
+ }
+ },
+
methods: {
- onDragover: function onDragover() {
- if (!this.disabled) {
- this.dragover = true;
+ 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();
}
},
- onDrop: function onDrop(e) {
- if (!this.disabled) {
- this.dragover = false;
- this.$emit('file', e.dataTransfer.files);
+ 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);
}
}
+ },
+
+ mounted: function mounted() {
+ var _this2 = this;
+
+ if (this.duration > 0) {
+ this.timer = setTimeout(function () {
+ if (!_this2.closed) {
+ _this2.close();
+ }
+ }, this.duration);
+ }
}
};
/***/ },
-/* 286 */
+/* 251 */
/***/ function(module, exports) {
module.exports={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
- },
+ return _c('transition', {
+ attrs: {
+ "name": "el-notification-fade"
+ }
+ }, [_c('div', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.visible),
+ expression: "visible"
+ }],
+ staticClass: "el-notification",
+ class: _vm.customClass,
+ style: ({
+ top: _vm.top ? _vm.top + 'px' : 'auto'
+ }),
on: {
- "drop": function($event) {
- $event.preventDefault();
- _vm.onDrop($event)
+ "mouseenter": function($event) {
+ _vm.clearTimer()
},
- "dragover": function($event) {
- $event.preventDefault();
- _vm.onDragover($event)
+ "mouseleave": function($event) {
+ _vm.startTimer()
},
- "dragleave": function($event) {
- $event.preventDefault();
- _vm.dragover = false
+ "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', {
+ staticClass: "el-notification__content"
+ }, [_vm._t("default", [_vm._v(_vm._s(_vm.message))])], 2), _c('div', {
+ staticClass: "el-notification__closeBtn el-icon-close",
+ on: {
+ "click": function($event) {
+ $event.stopPropagation();
+ _vm.close($event)
}
}
- }, [_vm._t("default")], 2)
+ })])])])
},staticRenderFns: []}
/***/ },
-/* 287 */
+/* 252 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _main = __webpack_require__(253);
+
+ var _main2 = _interopRequireDefault(_main);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _main2.default.install = function (Vue) {
+ Vue.component(_main2.default.name, _main2.default);
+ };
+
+ exports.default = _main2.default;
+
+/***/ },
+/* 253 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(288),
+ __webpack_require__(254),
/* template */
- null,
+ __webpack_require__(259),
/* styles */
null,
/* scopeId */
@@ -55939,260 +55072,308 @@ module.exports =
/***/ },
-/* 288 */
+/* 254 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _uploadDragger = __webpack_require__(284);
+ var _inputNumber = __webpack_require__(255);
- var _uploadDragger2 = _interopRequireDefault(_uploadDragger);
+ var _inputNumber2 = _interopRequireDefault(_inputNumber);
+
+ var _button = __webpack_require__(256);
+
+ var _button2 = _interopRequireDefault(_button);
+
+ var _emitter = __webpack_require__(15);
+
+ var _emitter2 = _interopRequireDefault(_emitter);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- components: {
- UploadDragger: _uploadDragger2.default
- },
+ name: 'ElSlider',
+
+ mixins: [_emitter2.default],
+
props: {
- type: String,
- data: {},
- action: {
- type: String,
- required: true
+ min: {
+ type: Number,
+ default: 0
},
- name: {
- type: String,
- default: 'file'
+ max: {
+ type: Number,
+ default: 100
},
- withCredentials: Boolean,
- accept: String,
- onStart: Function,
- onProgress: Function,
- onSuccess: Function,
- onError: Function,
- beforeUpload: Function,
- onPreview: {
- type: Function,
- default: function _default() {}
+ step: {
+ type: Number,
+ default: 1
},
- onRemove: {
- type: Function,
- default: function _default() {}
+ value: {
+ type: [Number, Array],
+ default: 0
},
- drag: Boolean,
- listType: String,
- disabled: Boolean
+ showInput: {
+ type: Boolean,
+ default: false
+ },
+ showInputControls: {
+ type: Boolean,
+ default: true
+ },
+ 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
+ }
+ },
+
+ components: {
+ ElInputNumber: _inputNumber2.default,
+ SliderButton: _button2.default
},
data: function data() {
return {
- mouseover: false,
- domain: '',
- file: null,
- submitting: false
+ firstValue: null,
+ secondValue: null,
+ oldValue: null,
+ dragging: false,
+ sliderSize: 1
};
},
- methods: {
- isImage: function isImage(str) {
- return str.indexOf('image') !== -1;
- },
- handleClick: function handleClick() {
- if (!this.disabled) {
- this.$refs.input.click();
+ 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();
},
- handleChange: function handleChange(ev) {
- var file = ev.target.value;
- if (file) {
- this.uploadFiles(file);
+ dragging: function dragging(val) {
+ if (!val) {
+ this.setValues();
}
},
- uploadFiles: function uploadFiles(file) {
- if (this.submitting) return;
- this.submitting = true;
- this.file = file;
- this.onStart(file);
-
- var formNode = this.getFormNode();
- var dataSpan = this.getFormDataNode();
- var data = this.data;
- if (typeof data === 'function') {
- data = data(file);
+ firstValue: function firstValue(val) {
+ if (this.range) {
+ this.$emit('input', [this.minValue, this.maxValue]);
+ } else {
+ this.$emit('input', val);
}
- var inputs = [];
- for (var key in data) {
- if (data.hasOwnProperty(key)) {
- inputs.push('');
- }
+ },
+ secondValue: function secondValue() {
+ if (this.range) {
+ this.$emit('input', [this.minValue, this.maxValue]);
}
- dataSpan.innerHTML = inputs.join('');
- formNode.submit();
- dataSpan.innerHTML = '';
},
- getFormNode: function getFormNode() {
- return this.$refs.form;
+ min: function min() {
+ this.setValues();
},
- getFormDataNode: function getFormDataNode() {
- return this.$refs.data;
+ max: function max() {
+ this.setValues();
}
},
- created: function created() {
- this.frameName = 'frame-' + Date.now();
- },
- mounted: function mounted() {
- var self = this;
- !this.$isServer && window.addEventListener('message', function (event) {
- if (!self.file) return;
- var targetOrigin = new URL(self.action).origin;
- if (event.origin !== targetOrigin) return;
- var response = event.data;
- if (response.result === 'success') {
- self.onSuccess(response, self.file);
- } else if (response.result === 'failed') {
- self.onError(response, self.file);
- }
- self.submitting = false;
- self.file = null;
- }, false);
- },
- render: function render(h) {
- var drag = this.drag,
- uploadFiles = this.uploadFiles,
- listType = this.listType,
- frameName = this.frameName,
- disabled = this.disabled;
-
- var oClass = { 'el-upload': true };
- oClass['el-upload--' + listType] = true;
+ methods: {
+ valueChanged: function valueChanged() {
+ var _this = this;
- return h(
- 'div',
- {
- 'class': oClass,
- on: {
- 'click': this.handleClick
- },
- nativeOn: {
- 'drop': this.onDrop,
- 'dragover': this.handleDragover,
- 'dragleave': this.handleDragleave
+ 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() {
+ 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.$emit('change', [this.minValue, this.maxValue]);
+ this.dispatch('ElFormItem', 'el.form.change', [this.minValue, this.maxValue]);
+ this.oldValue = val.slice();
+ }
}
- },
- [h(
- 'iframe',
- {
- on: {
- 'load': this.onload
- },
-
- ref: 'iframe',
- attrs: { name: frameName
+ } 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.$emit('change', val);
+ this.dispatch('ElFormItem', 'el.form.change', val);
+ this.oldValue = val;
}
- },
- []
- ), h(
- 'form',
- { ref: 'form', attrs: { action: this.action, target: frameName, enctype: 'multipart/form-data', method: 'POST' }
- },
- [h(
- 'input',
- {
- 'class': 'el-upload__input',
- attrs: { type: 'file',
-
- name: 'file',
-
- accept: this.accept },
- ref: 'input', on: {
- 'change': this.handleChange
- }
- },
- []
- ), h(
- 'input',
- {
- attrs: { type: 'hidden', name: 'documentDomain', value: this.$isServer ? '' : document.domain }
- },
- []
- ), h(
- 'span',
- { ref: 'data' },
- []
- )]
- ), drag ? h(
- 'upload-dragger',
- {
- on: {
- 'file': uploadFiles
- },
- attrs: { disabled: disabled }
- },
- [this.$slots.default]
- ) : this.$slots.default]
- );
- }
- };
-
-/***/ },
-/* 289 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(78);
-
-/***/ },
-/* 290 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _progress = __webpack_require__(291);
-
- var _progress2 = _interopRequireDefault(_progress);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _progress2.default.install = function (Vue) {
- Vue.component(_progress2.default.name, _progress2.default);
- };
-
- exports.default = _progress2.default;
-
-/***/ },
-/* 291 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(292),
- /* template */
- __webpack_require__(293),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
+ }
+ }
+ },
+ 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.disabled || 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);
+ }
+ },
+ resetSize: function resetSize() {
+ if (this.$refs.slider) {
+ this.sliderSize = this.$refs.slider['client' + (this.vertical ? 'Height' : 'Width')];
+ }
+ }
+ },
-/***/ },
-/* 292 */
-/***/ function(module, exports) {
+ computed: {
+ stops: function stops() {
+ var _this2 = this;
- 'use strict';
+ if (this.step === 0) {
+ ("production") !== 'production' && console.warn('[Element Warn][Slider]step should not be 0.');
+ 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 * (_this2.minValue - _this2.min) / (_this2.max - _this2.min) || step > 100 * (_this2.maxValue - _this2.min) / (_this2.max - _this2.min);
+ });
+ } else {
+ return result.filter(function (step) {
+ return step > 100 * (_this2.firstValue - _this2.min) / (_this2.max - _this2.min);
+ });
+ }
+ },
+ 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
+ };
+ }
+ },
- exports.__esModule = true;
+ mounted: function mounted() {
+ 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];
+ } 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;
+ }
+ this.resetSize();
+ window.addEventListener('resize', this.resetSize);
+ },
+ beforeDestroy: function beforeDestroy() {
+ window.removeEventListener('resize', this.resetSize);
+ }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
//
//
//
@@ -56228,192 +55409,22 @@ module.exports =
//
//
//
-
- exports.default = {
- name: 'ElProgress',
- props: {
- type: {
- type: String,
- default: 'line',
- validator: function validator(val) {
- return ['line', 'circle'].indexOf(val) > -1;
- }
- },
- percentage: {
- type: Number,
- default: 0,
- required: true,
- validator: function validator(val) {
- return val >= 0 && val <= 100;
- }
- },
- status: {
- type: String
- },
- strokeWidth: {
- type: Number,
- default: 6
- },
- textInside: {
- type: Boolean,
- default: false
- },
- width: {
- type: Number,
- default: 126
- },
- showText: {
- type: Boolean,
- default: true
- }
- },
- computed: {
- barStyle: function barStyle() {
- var style = {};
- style.width = this.percentage + '%';
- return style;
- },
- relativeStrokeWidth: function relativeStrokeWidth() {
- return (this.strokeWidth / this.width * 100).toFixed(1);
- },
- trackPath: function trackPath() {
- var radius = parseInt(50 - parseFloat(this.relativeStrokeWidth) / 2, 10);
-
- return 'M 50 50 m 0 -' + radius + ' a ' + radius + ' ' + radius + ' 0 1 1 0 ' + radius * 2 + ' a ' + radius + ' ' + radius + ' 0 1 1 0 -' + radius * 2;
- },
- perimeter: function perimeter() {
- var radius = 50 - parseFloat(this.relativeStrokeWidth) / 2;
- return 2 * Math.PI * radius;
- },
- circlePathStyle: function circlePathStyle() {
- var perimeter = this.perimeter;
- return {
- strokeDasharray: perimeter + 'px,' + perimeter + 'px',
- strokeDashoffset: (1 - this.percentage / 100) * perimeter + 'px',
- transition: 'stroke-dashoffset 0.6s ease 0s, stroke 0.6s ease'
- };
- },
- stroke: function stroke() {
- var ret;
- switch (this.status) {
- case 'success':
- ret = '#13ce66';
- break;
- case 'exception':
- ret = '#ff4949';
- break;
- default:
- ret = '#20a0ff';
- }
- return ret;
- },
- iconClass: function iconClass() {
- if (this.type === 'line') {
- return this.status === 'success' ? 'el-icon-circle-check' : 'el-icon-circle-cross';
- } 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;
- }
- }
- };
/***/ },
-/* 293 */
+/* 255 */
/***/ function(module, exports) {
- module.exports={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,
- }
- ]
- }, [(_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.percentage) + "%")]) : _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",
- 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-linecap": "round",
- "stroke": _vm.stroke,
- "stroke-width": _vm.relativeStrokeWidth,
- "fill": "none"
- }
- })])]), (_vm.showText && !_vm.textInside) ? _c('div', {
- staticClass: "el-progress__text",
- style: ({
- fontSize: _vm.progressTextSize + 'px'
- })
- }, [(!_vm.status) ? [_vm._v(_vm._s(_vm.percentage) + "%")] : _c('i', {
- class: _vm.iconClass
- })], 2) : _vm._e()])
- },staticRenderFns: []}
-
-/***/ },
-/* 294 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _spinner = __webpack_require__(295);
-
- var _spinner2 = _interopRequireDefault(_spinner);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _spinner2.default.install = function (Vue) {
- Vue.component(_spinner2.default.name, _spinner2.default);
- };
-
- exports.default = _spinner2.default;
+ module.exports = __webpack_require__(77);
/***/ },
-/* 295 */
+/* 256 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(296),
+ __webpack_require__(257),
/* template */
- __webpack_require__(297),
+ __webpack_require__(258),
/* styles */
null,
/* scopeId */
@@ -56426,180 +55437,462 @@ module.exports =
/***/ },
-/* 296 */
-/***/ function(module, exports) {
+/* 257 */
+/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
+
+ var _tooltip = __webpack_require__(138);
+
+ var _tooltip2 = _interopRequireDefault(_tooltip);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElSpinner',
+ name: 'ElSliderButton',
+
+ components: {
+ ElTooltip: _tooltip2.default
+ },
+
props: {
- type: String,
- radius: {
- type: Number,
- default: 100
- },
- strokeWidth: {
+ value: {
type: Number,
- default: 5
+ default: 0
},
- strokeColor: {
- type: String,
- default: '#efefef'
+ vertical: {
+ type: Boolean,
+ default: false
}
- }
- };
-
-/***/ },
-/* 297 */
-/***/ function(module, exports) {
+ },
- module.exports={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'
- }),
+ data: function data() {
+ return {
+ hovering: false,
+ dragging: false,
+ startX: 0,
+ currentX: 0,
+ startY: 0,
+ currentY: 0,
+ startPosition: 0,
+ newPosition: null,
+ oldValue: this.value
+ };
+ },
+
+
+ computed: {
+ disabled: function disabled() {
+ return this.$parent.disabled;
+ },
+ 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('mouseup', this.onDragEnd);
+ window.addEventListener('contextmenu', this.onDragEnd);
+ },
+ onDragStart: function onDragStart(event) {
+ this.dragging = true;
+ if (this.vertical) {
+ this.startY = event.clientY;
+ } else {
+ this.startX = event.clientX;
+ }
+ this.startPosition = parseFloat(this.currentPosition);
+ },
+ onDragging: function onDragging(event) {
+ if (this.dragging) {
+ this.displayTooltip();
+ this.$parent.resetSize();
+ var diff = 0;
+ 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();
+ _this.setPosition(_this.newPosition);
+ }, 0);
+ window.removeEventListener('mousemove', this.onDragging);
+ window.removeEventListener('mouseup', this.onDragEnd);
+ window.removeEventListener('contextmenu', this.onDragEnd);
+ }
+ },
+ setPosition: function setPosition(newPosition) {
+ if (newPosition === null) 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.$refs.tooltip && this.$refs.tooltip.updatePopper();
+ if (!this.dragging && this.value !== this.oldValue) {
+ this.oldValue = this.value;
+ }
+ }
+ }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+/***/ },
+/* 258 */
+/***/ function(module, exports) {
+
+ module.exports={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),
+ on: {
+ "mouseenter": _vm.handleMouseEnter,
+ "mouseleave": _vm.handleMouseLeave,
+ "mousedown": _vm.onButtonDown
+ }
+ }, [_c('el-tooltip', {
+ ref: "tooltip",
attrs: {
- "viewBox": "0 0 50 50"
+ "placement": "top",
+ "disabled": !_vm.showTooltip
}
- }, [_c('circle', {
- staticClass: "path",
+ }, [_c('span', {
+ slot: "content"
+ }, [_vm._v(_vm._s(_vm.formatValue))]), _c('div', {
+ staticClass: "el-slider__button",
+ class: {
+ 'hover': _vm.hovering, 'dragging': _vm.dragging
+ }
+ })])], 1)
+ },staticRenderFns: []}
+
+/***/ },
+/* 259 */
+/***/ function(module, exports) {
+
+ module.exports={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
+ }
+ }, [(_vm.showInput && !_vm.range) ? _c('el-input-number', {
+ ref: "input",
+ staticClass: "el-slider__input",
attrs: {
- "cx": "25",
- "cy": "25",
- "r": "20",
- "fill": "none",
- "stroke": _vm.strokeColor,
- "stroke-width": _vm.strokeWidth
+ "step": _vm.step,
+ "disabled": _vm.disabled,
+ "controls": _vm.showInputControls,
+ "min": _vm.min,
+ "max": _vm.max,
+ "debounce": _vm.debounce,
+ "size": "small"
+ },
+ 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.disabled
+ },
+ 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
+ },
+ model: {
+ value: (_vm.firstValue),
+ callback: function($$v) {
+ _vm.firstValue = $$v
+ },
+ expression: "firstValue"
+ }
+ }), (_vm.range) ? _c('slider-button', {
+ ref: "button2",
+ attrs: {
+ "vertical": _vm.vertical
+ },
+ model: {
+ value: (_vm.secondValue),
+ callback: function($$v) {
+ _vm.secondValue = $$v
+ },
+ expression: "secondValue"
+ }
+ }) : _vm._e(), _vm._l((_vm.stops), function(item) {
+ return (_vm.showStops) ? _c('div', {
+ staticClass: "el-slider__stop",
+ style: (_vm.vertical ? {
+ 'bottom': item + '%'
+ } : {
+ 'left': item + '%'
+ })
+ }) : _vm._e()
+ })], 2)], 1)
},staticRenderFns: []}
/***/ },
-/* 298 */
+/* 260 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(299);
+ var _directive = __webpack_require__(261);
- var _main2 = _interopRequireDefault(_main);
+ var _directive2 = _interopRequireDefault(_directive);
+
+ var _index = __webpack_require__(265);
+
+ var _index2 = _interopRequireDefault(_index);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- exports.default = _main2.default;
+ exports.default = {
+ install: function install(Vue) {
+ Vue.use(_directive2.default);
+ Vue.prototype.$loading = _index2.default;
+ },
+
+ directive: _directive2.default,
+ service: _index2.default
+ };
/***/ },
-/* 299 */
+/* 261 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
- exports.__esModule = true;
-
var _vue = __webpack_require__(133);
var _vue2 = _interopRequireDefault(_vue);
- var _popup = __webpack_require__(14);
-
- var _vdom = __webpack_require__(194);
+ var _dom = __webpack_require__(44);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var MessageConstructor = _vue2.default.extend(__webpack_require__(300));
+ var Mask = _vue2.default.extend(__webpack_require__(262));
- var instance = void 0;
- var instances = [];
- var seed = 1;
+ exports.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 = (0, _dom.getStyle)(document.body, 'position');
+ el.originalOverflow = (0, _dom.getStyle)(document.body, 'overflow');
- var Message = function Message(options) {
- if (_vue2.default.prototype.$isServer) return;
- options = options || {};
- if (typeof options === 'string') {
- options = {
- message: options
- };
- }
- var userOnClose = options.onClose;
- var id = 'message_' + seed++;
+ (0, _dom.addClass)(el.mask, 'is-fullscreen');
+ insertDom(document.body, el, binding);
+ } else {
+ (0, _dom.removeClass)(el.mask, 'is-fullscreen');
- options.onClose = function () {
- Message.close(id, userOnClose);
- };
- instance = new MessageConstructor({
- data: options
- });
- instance.id = id;
- if ((0, _vdom.isVNode)(instance.message)) {
- instance.$slots.default = [instance.message];
- instance.message = null;
- }
- instance.vm = instance.$mount();
- document.body.appendChild(instance.vm.$el);
- instance.vm.visible = true;
- instance.dom = instance.vm.$el;
- instance.dom.style.zIndex = _popup.PopupManager.nextZIndex();
- instances.push(instance);
- return instance.vm;
- };
+ if (binding.modifiers.body) {
+ el.originalPosition = (0, _dom.getStyle)(document.body, 'position');
- ['success', 'warning', 'info', 'error'].forEach(function (type) {
- Message[type] = function (options) {
- if (typeof options === 'string') {
- options = {
- message: options
- };
+ ['top', 'left'].forEach(function (property) {
+ var scroll = property === 'top' ? 'scrollTop' : 'scrollLeft';
+ el.maskStyle[property] = el.getBoundingClientRect()[property] + document.body[scroll] + document.documentElement[scroll] + 'px';
+ });
+ ['height', 'width'].forEach(function (property) {
+ el.maskStyle[property] = el.getBoundingClientRect()[property] + 'px';
+ });
+
+ insertDom(document.body, el, binding);
+ } else {
+ el.originalPosition = (0, _dom.getStyle)(el, 'position');
+ insertDom(el, el, binding);
+ }
+ }
+ });
+ } else {
+ if (el.domVisible) {
+ el.instance.$on('after-leave', function (_) {
+ el.domVisible = false;
+ if (binding.modifiers.fullscreen && el.originalOverflow !== 'hidden') {
+ document.body.style.overflow = el.originalOverflow;
+ }
+ if (binding.modifiers.fullscreen || binding.modifiers.body) {
+ document.body.style.position = el.originalPosition;
+ } else {
+ el.style.position = el.originalPosition;
+ }
+ });
+ el.instance.visible = false;
+ }
}
- options.type = type;
- return Message(options);
};
- });
+ var insertDom = function insertDom(parent, el, binding) {
+ if (!el.domVisible && (0, _dom.getStyle)(el, 'display') !== 'none' && (0, _dom.getStyle)(el, 'visibility') !== 'hidden') {
+ Object.keys(el.maskStyle).forEach(function (property) {
+ el.mask.style[property] = el.maskStyle[property];
+ });
- Message.close = function (id, userOnClose) {
- for (var i = 0, len = instances.length; i < len; i++) {
- if (id === instances[i].id) {
- if (typeof userOnClose === 'function') {
- userOnClose(instances[i]);
+ if (el.originalPosition !== 'absolute' && el.originalPosition !== 'fixed') {
+ parent.style.position = 'relative';
}
- instances.splice(i, 1);
- break;
+ if (binding.modifiers.fullscreen && binding.modifiers.lock) {
+ parent.style.overflow = 'hidden';
+ }
+ el.domVisible = true;
+
+ parent.appendChild(el.mask);
+ Vue.nextTick(function () {
+ el.instance.visible = true;
+ });
+ el.domInserted = true;
}
- }
- };
+ };
- Message.closeAll = function () {
- for (var i = instances.length - 1; i >= 0; i--) {
- instances[i].close();
- }
- };
+ Vue.directive('loading', {
+ bind: function bind(el, binding) {
+ var mask = new Mask({
+ el: document.createElement('div'),
+ data: {
+ text: el.getAttribute('element-loading-text'),
+ fullscreen: !!binding.modifiers.fullscreen
+ }
+ });
+ el.instance = mask;
+ el.mask = mask.$el;
+ el.maskStyle = {};
- exports.default = Message;
+ 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) {
+ if (binding.modifiers.fullscreen || binding.modifiers.body) {
+ document.body.removeChild(el.mask);
+ } else {
+ el.mask && el.mask.parentNode && el.mask.parentNode.removeChild(el.mask);
+ }
+ }
+ }
+ });
+ };
/***/ },
-/* 300 */
+/* 262 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(301),
+ __webpack_require__(263),
/* template */
- __webpack_require__(307),
+ __webpack_require__(264),
/* styles */
null,
/* scopeId */
@@ -56612,8 +55905,8 @@ module.exports =
/***/ },
-/* 301 */
-/***/ function(module, exports, __webpack_require__) {
+/* 263 */
+/***/ function(module, exports) {
'use strict';
@@ -56634,129 +55927,39 @@ module.exports =
//
//
//
- //
exports.default = {
data: function data() {
return {
+ text: null,
+ fullscreen: true,
visible: false,
- message: '',
- duration: 3000,
- type: 'info',
- iconClass: '',
- customClass: '',
- onClose: null,
- showClose: false,
- closed: false,
- timer: null
+ customClass: ''
};
},
- computed: {
- typeImg: function typeImg() {
- return __webpack_require__(302)("./" + this.type + '.svg');
+ methods: {
+ handleAfterLeave: function handleAfterLeave() {
+ this.$emit('after-leave');
+ },
+ setText: function setText(text) {
+ this.text = text;
}
- },
+ }
+ };
- watch: {
- closed: function closed(newVal) {
- if (newVal) {
- this.visible = false;
- this.$el.addEventListener('transitionend', this.destroyElement);
- }
- }
- },
+/***/ },
+/* 264 */
+/***/ function(module, exports) {
- methods: {
- destroyElement: function destroyElement() {
- this.$el.removeEventListener('transitionend', this.destroyElement);
- this.$destroy(true);
- this.$el.parentNode.removeChild(this.$el);
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('transition', {
+ attrs: {
+ "name": "el-loading-fade"
},
- 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);
- }
- }
- },
-
- mounted: function mounted() {
- this.startTimer();
- }
- };
-
-/***/ },
-/* 302 */
-/***/ function(module, exports, __webpack_require__) {
-
- var map = {
- "./error.svg": 303,
- "./info.svg": 304,
- "./success.svg": 305,
- "./warning.svg": 306
- };
- function webpackContext(req) {
- return __webpack_require__(webpackContextResolve(req));
- };
- function webpackContextResolve(req) {
- return map[req] || (function() { throw new Error("Cannot find module '" + req + "'.") }());
- };
- webpackContext.keys = function webpackContextKeys() {
- return Object.keys(map);
- };
- webpackContext.resolve = webpackContextResolve;
- module.exports = webpackContext;
- webpackContext.id = 302;
-
-
-/***/ },
-/* 303 */
-/***/ function(module, exports) {
-
- module.exports = ""
-
-/***/ },
-/* 304 */
-/***/ function(module, exports) {
-
- module.exports = ""
-
-/***/ },
-/* 305 */
-/***/ function(module, exports) {
-
- module.exports = ""
-
-/***/ },
-/* 306 */
-/***/ function(module, exports) {
-
- module.exports = ""
-
-/***/ },
-/* 307 */
-/***/ function(module, exports) {
-
- module.exports={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: [{
@@ -56765,181 +55968,185 @@ module.exports =
value: (_vm.visible),
expression: "visible"
}],
- staticClass: "el-message",
- class: _vm.customClass,
- on: {
- "mouseenter": _vm.clearTimer,
- "mouseleave": _vm.startTimer
- }
- }, [(!_vm.iconClass) ? _c('img', {
- staticClass: "el-message__img",
+ staticClass: "el-loading-mask",
+ class: [_vm.customClass, {
+ 'is-fullscreen': _vm.fullscreen
+ }]
+ }, [_c('div', {
+ staticClass: "el-loading-spinner"
+ }, [_c('svg', {
+ staticClass: "circular",
attrs: {
- "src": _vm.typeImg,
- "alt": ""
- }
- }) : _vm._e(), _c('div', {
- staticClass: "el-message__group",
- class: {
- 'is-with-icon': _vm.iconClass
+ "viewBox": "25 25 50 50"
}
- }, [_vm._t("default", [_c('p', [(_vm.iconClass) ? _c('i', {
- staticClass: "el-message__icon",
- class: _vm.iconClass
- }) : _vm._e(), _vm._v(_vm._s(_vm.message))])]), (_vm.showClose) ? _c('div', {
- staticClass: "el-message__closeBtn el-icon-close",
- on: {
- "click": _vm.close
+ }, [_c('circle', {
+ staticClass: "path",
+ attrs: {
+ "cx": "50",
+ "cy": "50",
+ "r": "20",
+ "fill": "none"
}
- }) : _vm._e()], 2)])])
+ })]), (_vm.text) ? _c('p', {
+ staticClass: "el-loading-text"
+ }, [_vm._v(_vm._s(_vm.text))]) : _vm._e()])])])
},staticRenderFns: []}
/***/ },
-/* 308 */
+/* 265 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(309);
+ var _vue = __webpack_require__(133);
- var _main2 = _interopRequireDefault(_main);
+ var _vue2 = _interopRequireDefault(_vue);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _loading = __webpack_require__(262);
- /* istanbul ignore next */
- _main2.default.install = function (Vue) {
- Vue.component(_main2.default.name, _main2.default);
- };
+ var _loading2 = _interopRequireDefault(_loading);
- exports.default = _main2.default;
+ var _dom = __webpack_require__(44);
-/***/ },
-/* 309 */
-/***/ function(module, exports, __webpack_require__) {
+ var _merge = __webpack_require__(64);
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(310),
- /* template */
- __webpack_require__(311),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ var _merge2 = _interopRequireDefault(_merge);
- module.exports = Component.exports
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var LoadingConstructor = _vue2.default.extend(_loading2.default);
-/***/ },
-/* 310 */
-/***/ function(module, exports) {
+ var defaults = {
+ text: null,
+ fullscreen: true,
+ body: false,
+ lock: false,
+ customClass: ''
+ };
- 'use strict';
+ var fullscreenLoading = void 0;
- exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ LoadingConstructor.prototype.originalPosition = '';
+ LoadingConstructor.prototype.originalOverflow = '';
- exports.default = {
- name: 'ElBadge',
+ LoadingConstructor.prototype.close = function () {
+ var _this = this;
- props: {
- value: {},
- max: Number,
- isDot: Boolean,
- hidden: Boolean
- },
+ if (this.fullscreen && this.originalOverflow !== 'hidden') {
+ document.body.style.overflow = this.originalOverflow;
+ }
+ if (this.fullscreen || this.body) {
+ document.body.style.position = this.originalPosition;
+ } else {
+ this.target.style.position = this.originalPosition;
+ }
+ if (this.fullscreen) {
+ fullscreenLoading = undefined;
+ }
+ this.$on('after-leave', function (_) {
+ _this.$el && _this.$el.parentNode && _this.$el.parentNode.removeChild(_this.$el);
+ _this.$destroy();
+ });
+ this.visible = false;
+ };
- computed: {
- content: function content() {
- if (this.isDot) return;
+ var addStyle = function addStyle(options, parent, instance) {
+ var maskStyle = {};
+ if (options.fullscreen) {
+ instance.originalPosition = (0, _dom.getStyle)(document.body, 'position');
+ instance.originalOverflow = (0, _dom.getStyle)(document.body, 'overflow');
+ } else if (options.body) {
+ instance.originalPosition = (0, _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 = (0, _dom.getStyle)(parent, 'position');
+ }
+ Object.keys(maskStyle).forEach(function (property) {
+ instance.$el.style[property] = maskStyle[property];
+ });
+ };
- var value = this.value;
- var max = this.max;
+ var Loading = function Loading() {
+ var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
- if (typeof value === 'number' && typeof max === 'number') {
- return max < value ? max + '+' : value;
- }
+ if (_vue2.default.prototype.$isServer) return;
+ options = (0, _merge2.default)({}, 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;
+ }
- return value;
- }
+ var parent = options.body ? document.body : options.target;
+ var instance = new LoadingConstructor({
+ el: document.createElement('div'),
+ data: options
+ });
+
+ addStyle(options, parent, instance);
+ if (instance.originalPosition !== 'absolute' && instance.originalPosition !== 'fixed') {
+ parent.style.position = 'relative';
+ }
+ if (options.fullscreen && options.lock) {
+ parent.style.overflow = 'hidden';
}
+ parent.appendChild(instance.$el);
+ _vue2.default.nextTick(function () {
+ instance.visible = true;
+ });
+ if (options.fullscreen) {
+ fullscreenLoading = instance;
+ }
+ return instance;
};
-/***/ },
-/* 311 */
-/***/ function(module, exports) {
-
- module.exports={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.isDot)),
- expression: "!hidden && ( content || isDot )"
- }],
- staticClass: "el-badge__content",
- class: {
- 'is-fixed': _vm.$slots.default, 'is-dot': _vm.isDot
- },
- domProps: {
- "textContent": _vm._s(_vm.content)
- }
- })])], 2)
- },staticRenderFns: []}
+ exports.default = Loading;
/***/ },
-/* 312 */
+/* 266 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(313);
+ var _icon = __webpack_require__(267);
- var _main2 = _interopRequireDefault(_main);
+ var _icon2 = _interopRequireDefault(_icon);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _main2.default.install = function (Vue) {
- Vue.component(_main2.default.name, _main2.default);
+ _icon2.default.install = function (Vue) {
+ Vue.component(_icon2.default.name, _icon2.default);
};
- exports.default = _main2.default;
+ exports.default = _icon2.default;
/***/ },
-/* 313 */
+/* 267 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(314),
+ __webpack_require__(268),
/* template */
- __webpack_require__(315),
+ __webpack_require__(269),
/* styles */
null,
/* scopeId */
@@ -56952,7 +56159,7 @@ module.exports =
/***/ },
-/* 314 */
+/* 268 */
/***/ function(module, exports) {
'use strict';
@@ -56962,418 +56169,224 @@ module.exports =
//
//
//
- //
- //
- //
- //
- //
- //
- //
exports.default = {
- name: 'ElCard',
+ name: 'ElIcon',
- props: ['header', 'bodyStyle']
+ props: {
+ name: String
+ }
};
/***/ },
-/* 315 */
+/* 269 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-card"
- }, [(_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)])
+ return _c('i', {
+ class: 'el-icon-' + _vm.name
+ })
},staticRenderFns: []}
/***/ },
-/* 316 */
+/* 270 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(317);
+ var _row = __webpack_require__(271);
- var _main2 = _interopRequireDefault(_main);
+ var _row2 = _interopRequireDefault(_row);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _main2.default.install = function (Vue) {
- Vue.component(_main2.default.name, _main2.default);
+ _row2.default.install = function (Vue) {
+ Vue.component(_row2.default.name, _row2.default);
};
- exports.default = _main2.default;
+ exports.default = _row2.default;
/***/ },
-/* 317 */
-/***/ function(module, exports, __webpack_require__) {
+/* 271 */
+/***/ function(module, exports) {
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(318),
- /* template */
- __webpack_require__(319),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ 'use strict';
- module.exports = Component.exports
+ exports.__esModule = true;
+ exports.default = {
+ 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);
+ }
+ };
/***/ },
-/* 318 */
+/* 272 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _dom = __webpack_require__(44);
+ var _col = __webpack_require__(273);
- exports.default = {
- name: 'ElRate',
+ var _col2 = _interopRequireDefault(_col);
- data: function data() {
- return {
- classMap: {},
- colorMap: {},
- pointerAtLeftHalf: true,
- currentValue: this.value,
- hoverIndex: -1
- };
- },
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _col2.default.install = function (Vue) {
+ Vue.component(_col2.default.name, _col2.default);
+ };
+ exports.default = _col2.default;
+
+/***/ },
+/* 273 */
+/***/ function(module, exports) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ 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; };
+
+ exports.default = {
+ name: 'ElCol',
props: {
- value: {
- type: Number,
- default: 0
- },
- lowThreshold: {
- type: Number,
- default: 2
- },
- highThreshold: {
- type: Number,
- default: 4
- },
- max: {
+ span: {
type: Number,
- default: 5
- },
- colors: {
- type: Array,
- default: function _default() {
- return ['#F7BA2A', '#F7BA2A', '#F7BA2A'];
- }
- },
- voidColor: {
- type: String,
- default: '#C6D1DE'
+ default: 24
},
- disabledVoidColor: {
+ tag: {
type: String,
- default: '#EFF2F7'
+ default: 'div'
},
- iconClasses: {
- type: Array,
- default: function _default() {
- return ['el-icon-star-on', 'el-icon-star-on', 'el-icon-star-on'];
+ offset: Number,
+ pull: Number,
+ push: Number,
+ xs: [Number, Object],
+ sm: [Number, Object],
+ md: [Number, Object],
+ lg: [Number, Object]
+ },
+
+ computed: {
+ gutter: function gutter() {
+ var parent = this.$parent;
+ while (parent && parent.$options.componentName !== 'ElRow') {
+ parent = parent.$parent;
}
- },
- 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
- },
- textColor: {
- type: String,
- default: '#1f2d3d'
- },
- texts: {
- type: Array,
- default: function _default() {
- return ['极差', '失望', '一般', '满意', '惊喜'];
- }
- },
- textTemplate: {
- type: String,
- default: '{value}'
+ return parent ? parent.gutter : 0;
}
},
+ render: function render(h) {
+ var _this = this;
- computed: {
- text: function text() {
- var result = '';
- if (this.disabled) {
- result = this.textTemplate.replace(/\{\s*value\s*\}/, this.value);
- } else {
- result = this.texts[Math.ceil(this.currentValue) - 1];
- }
- return result;
- },
- decimalStyle: function decimalStyle() {
- var width = '';
- if (this.disabled) {
- width = (this.valueDecimal < 50 ? 0 : 50) + '%';
- }
- if (this.allowHalf) {
- width = '50%';
- }
- return {
- color: this.activeColor,
- width: width
- };
- },
- valueDecimal: function valueDecimal() {
- return this.value * 100 - Math.floor(this.value) * 100;
- },
- decimalIconClass: function decimalIconClass() {
- return this.getValueFromMap(this.value, this.classMap);
- },
- voidClass: function voidClass() {
- return this.disabled ? this.classMap.disabledVoidClass : this.classMap.voidClass;
- },
- activeClass: function activeClass() {
- return this.getValueFromMap(this.currentValue, this.classMap);
- },
- 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;
- }
- },
+ var classList = [];
+ var style = {};
- watch: {
- value: function value(val) {
- this.$emit('change', val);
- this.currentValue = val;
- this.pointerAtLeftHalf = this.value !== Math.floor(this.value);
+ if (this.gutter) {
+ style.paddingLeft = this.gutter / 2 + 'px';
+ style.paddingRight = style.paddingLeft;
}
- },
- methods: {
- getValueFromMap: function getValueFromMap(value, map) {
- var result = '';
- if (value <= this.lowThreshold) {
- result = map.lowColor || map.lowClass;
- } else if (value >= this.highThreshold) {
- result = map.highColor || map.highClass;
- } else {
- result = map.mediumColor || map.mediumClass;
- }
- return result;
- },
- showDecimalIcon: function showDecimalIcon(item) {
- var showWhenDisabled = this.disabled && 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.disabled ? this.colorMap.disabledVoidColor : this.colorMap.voidColor;
- return {
- color: item <= this.currentValue ? this.activeColor : voidColor
- };
- },
- selectValue: function selectValue(value) {
- if (this.disabled) {
- return;
- }
- if (this.allowHalf && this.pointerAtLeftHalf) {
- this.$emit('input', this.currentValue);
- } else {
- this.$emit('input', value);
- }
- },
- setCurrentValue: function setCurrentValue(value, event) {
- if (this.disabled) {
- return;
- }
- /* istanbul ignore if */
- if (this.allowHalf) {
- var target = event.target;
- if ((0, _dom.hasClass)(target, 'el-rate__item')) {
- target = target.querySelector('.el-rate__icon');
- }
- if ((0, _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.disabled) {
- return;
+ ['span', 'offset', 'pull', 'push'].forEach(function (prop) {
+ if (_this[prop]) {
+ classList.push(prop !== 'span' ? 'el-col-' + prop + '-' + _this[prop] : 'el-col-' + _this[prop]);
}
- if (this.allowHalf) {
- this.pointerAtLeftHalf = this.value !== Math.floor(this.value);
+ });
+
+ ['xs', 'sm', 'md', 'lg'].forEach(function (size) {
+ if (typeof _this[size] === 'number') {
+ classList.push('el-col-' + size + '-' + _this[size]);
+ } else if (_typeof(_this[size]) === 'object') {
+ (function () {
+ 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]);
+ });
+ })();
}
- this.currentValue = this.value;
- this.hoverIndex = -1;
- }
- },
+ });
- created: function created() {
- if (!this.value) {
- this.$emit('input', 0);
- }
- this.classMap = {
- lowClass: this.iconClasses[0],
- mediumClass: this.iconClasses[1],
- highClass: this.iconClasses[2],
- voidClass: this.voidIconClass,
- disabledVoidClass: this.disabledVoidIconClass
- };
- this.colorMap = {
- lowColor: this.colors[0],
- mediumColor: this.colors[1],
- highColor: this.colors[2],
- voidColor: this.voidColor,
- disabledVoidColor: this.disabledVoidColor
- };
+ return h(this.tag, {
+ class: ['el-col', classList],
+ style: style
+ }, this.$slots.default);
}
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
-
-/***/ },
-/* 319 */
-/***/ function(module, exports) {
-
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-rate"
- }, [_vm._l((_vm.max), function(item) {
- return _c('span', {
- staticClass: "el-rate__item",
- style: ({
- cursor: _vm.disabled ? '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) ? _c('span', {
- staticClass: "el-rate__text",
- style: ({
- color: _vm.textColor
- })
- }, [_vm._v(_vm._s(_vm.text))]) : _vm._e()], 2)
- },staticRenderFns: []}
+ };
/***/ },
-/* 320 */
+/* 274 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _steps = __webpack_require__(321);
+ var _src = __webpack_require__(275);
- var _steps2 = _interopRequireDefault(_steps);
+ var _src2 = _interopRequireDefault(_src);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _steps2.default.install = function (Vue) {
- Vue.component(_steps2.default.name, _steps2.default);
+ _src2.default.install = function (Vue) {
+ Vue.component(_src2.default.name, _src2.default);
};
- exports.default = _steps2.default;
+ exports.default = _src2.default;
/***/ },
-/* 321 */
+/* 275 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(322),
+ __webpack_require__(276),
/* template */
- __webpack_require__(323),
+ null,
/* styles */
null,
/* scopeId */
@@ -57386,114 +56399,319 @@ module.exports =
/***/ },
-/* 322 */
-/***/ function(module, exports) {
+/* 276 */
+/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
+
+ var _uploadList = __webpack_require__(277);
+
+ var _uploadList2 = _interopRequireDefault(_uploadList);
+
+ var _upload = __webpack_require__(281);
+
+ var _upload2 = _interopRequireDefault(_upload);
+
+ var _iframeUpload = __webpack_require__(287);
+
+ var _iframeUpload2 = _interopRequireDefault(_iframeUpload);
+
+ var _progress = __webpack_require__(279);
+
+ var _progress2 = _interopRequireDefault(_progress);
+
+ var _migrating = __webpack_require__(289);
+
+ var _migrating2 = _interopRequireDefault(_migrating);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ function noop() {}
exports.default = {
- name: 'ElSteps',
+ name: 'ElUpload',
+
+ mixins: [_migrating2.default],
+
+ components: {
+ ElProgress: _progress2.default,
+ UploadList: _uploadList2.default,
+ Upload: _upload2.default,
+ IframeUpload: _iframeUpload2.default
+ },
+
+ provide: {
+ uploader: undefined
+ },
props: {
- space: [Number, String],
- active: Number,
- direction: {
+ action: {
type: String,
- default: 'horizontal'
+ required: true
},
- alignCenter: Boolean,
- center: Boolean,
- finishStatus: {
+ headers: {
+ type: Object,
+ default: function _default() {
+ return {};
+ }
+ },
+ data: Object,
+ multiple: Boolean,
+ name: {
type: String,
- default: 'finish'
+ default: 'file'
},
- processStatus: {
+ drag: Boolean,
+ dragger: Boolean,
+ withCredentials: Boolean,
+ showFileList: {
+ type: Boolean,
+ default: true
+ },
+ accept: String,
+ type: {
type: String,
- default: 'process'
- }
+ default: 'select'
+ },
+ beforeUpload: Function,
+ onRemove: {
+ type: Function,
+ default: noop
+ },
+ onChange: {
+ type: Function,
+ default: noop
+ },
+ onPreview: {
+ type: Function
+ },
+ onSuccess: {
+ type: Function,
+ default: noop
+ },
+ onProgress: {
+ type: Function,
+ default: noop
+ },
+ onError: {
+ type: Function,
+ default: 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
},
data: function data() {
return {
- steps: [],
- stepOffset: 0
+ uploadFiles: [],
+ dragOver: false,
+ draging: false,
+ tempIndex: 1
};
},
watch: {
- active: function active(newVal, oldVal) {
- this.$emit('change', newVal, oldVal);
- },
- steps: function steps(_steps) {
- var _this = this;
+ fileList: {
+ immediate: true,
+ handler: function handler(fileList) {
+ var _this = this;
- _steps.forEach(function (child, index) {
- child.index = index;
- });
- if (this.center) {
- (function () {
- var len = _steps.length;
- _this.$nextTick(function () {
- _this.stepOffset = _steps[len - 1].$el.getBoundingClientRect().width / (len - 1);
- });
- })();
+ this.uploadFiles = fileList.map(function (item) {
+ item.uid = item.uid || Date.now() + _this.tempIndex++;
+ item.status = 'success';
+ return item;
+ });
}
}
- }
- };
-
-/***/ },
-/* 323 */
-/***/ function(module, exports) {
-
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-steps",
- class: ['is-' + _vm.direction, _vm.center ? 'is-center' : '']
- }, [_vm._t("default")], 2)
- },staticRenderFns: []}
-
-/***/ },
-/* 324 */
-/***/ function(module, exports, __webpack_require__) {
+ },
- 'use strict';
+ 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
+ };
- exports.__esModule = true;
+ try {
+ file.url = URL.createObjectURL(rawFile);
+ } catch (err) {
+ console.error(err);
+ return;
+ }
- var _step = __webpack_require__(325);
+ 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);
- var _step2 = _interopRequireDefault(_step);
+ if (file) {
+ file.status = 'success';
+ file.response = res;
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ 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;
- /* istanbul ignore next */
- _step2.default.install = function (Vue) {
- Vue.component(_step2.default.name, _step2.default);
- };
+ file.status = 'fail';
- exports.default = _step2.default;
+ fileList.splice(fileList.indexOf(file), 1);
-/***/ },
-/* 325 */
-/***/ function(module, exports, __webpack_require__) {
+ this.onError(err, file, this.uploadFiles);
+ this.onChange(file, this.uploadFiles);
+ },
+ handleRemove: function handleRemove(file, raw) {
+ if (raw) {
+ file = this.getFile(raw);
+ }
+ this.abort(file);
+ var fileList = this.uploadFiles;
+ fileList.splice(fileList.indexOf(file), 1);
+ this.onRemove(file, fileList);
+ },
+ getFile: function getFile(rawFile) {
+ var fileList = this.uploadFiles;
+ var target;
+ 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 _this2 = this;
+
+ this.uploadFiles.filter(function (file) {
+ return file.status === 'ready';
+ }).forEach(function (file) {
+ _this2.$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'
+ }
+ };
+ }
+ },
+
+ render: function render(h) {
+ var uploadList;
+
+ if (this.showFileList) {
+ uploadList = h(
+ _uploadList2.default,
+ {
+ attrs: {
+ disabled: this.disabled,
+ listType: this.listType,
+ files: this.uploadFiles,
+
+ handlePreview: this.onPreview },
+ on: {
+ 'remove': this.handleRemove
+ }
+ },
+ []
+ );
+ }
+
+ 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.disabled,
+ '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 = typeof FormData !== 'undefined' || this.$isServer ? h(
+ 'upload',
+ uploadData,
+ [trigger]
+ ) : h(
+ 'iframeUpload',
+ uploadData,
+ [trigger]
+ );
+
+ return h(
+ 'div',
+ null,
+ [this.listType === 'picture-card' ? uploadList : '', this.$slots.trigger ? [uploadComponent, this.$slots.default] : uploadComponent, this.$slots.tip, this.listType !== 'picture-card' ? uploadList : '']
+ );
+ }
+ };
+
+/***/ },
+/* 277 */
+/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(326),
+ __webpack_require__(278),
/* template */
- __webpack_require__(327),
+ __webpack_require__(280),
/* styles */
null,
/* scopeId */
@@ -57506,12 +56724,33 @@ module.exports =
/***/ },
-/* 326 */
-/***/ function(module, exports) {
+/* 278 */
+/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
+
+ var _locale = __webpack_require__(10);
+
+ var _locale2 = _interopRequireDefault(_locale);
+
+ var _progress = __webpack_require__(279);
+
+ var _progress2 = _interopRequireDefault(_progress);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
//
//
//
@@ -57560,197 +56799,129 @@ module.exports =
//
exports.default = {
- name: 'ElStep',
-
- props: {
- title: String,
- icon: String,
- description: String,
- status: String
- },
-
- data: function data() {
- return {
- index: -1,
- lineStyle: {},
- mainOffset: 0,
- 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);
- }
- },
+ mixins: [_locale2.default],
+ components: { ElProgress: _progress2.default },
- 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';
+ props: {
+ files: {
+ type: Array,
+ default: function _default() {
+ return [];
+ }
},
-
- isLast: function isLast() {
- var parent = this.$parent;
- return parent.steps[parent.steps.length - 1] === this;
+ disabled: {
+ type: Boolean,
+ default: false
},
- style: function style() {
- var parent = this.$parent;
- var isCenter = parent.center;
- var len = parent.steps.length;
-
- if (isCenter && this.isLast) {
- return {};
- }
-
- var space = typeof parent.space === 'number' ? parent.space + 'px' : parent.space ? parent.space : 100 / (isCenter ? len - 1 : len) + '%';
- if (parent.direction === 'horizontal') {
- return { width: space };
- } else {
- if (!this.isLast) {
- return { height: space };
- }
- }
- }
+ handlePreview: Function,
+ listType: String
},
-
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);
+ parsePercentage: function parsePercentage(val) {
+ return parseInt(val, 10);
},
- calcProgress: function calcProgress(status) {
- var step = 100;
- var style = {};
-
- style.transitionDelay = 150 * this.index + 'ms';
- if (status === this.$parent.processStatus) {
- step = this.currentStatus !== 'error' ? 50 : 0;
- } else if (status === 'wait') {
- step = 0;
- style.transitionDelay = -150 * this.index + 'ms';
- }
-
- style.borderWidth = step ? '1px' : 0;
- this.$parent.direction === 'vertical' ? style.height = step + '%' : style.width = step + '%';
-
- this.lineStyle = style;
- }
- },
-
- mounted: function mounted() {
- var _this = this;
-
- var parent = this.$parent;
-
- if (parent.direction === 'horizontal') {
- if (parent.alignCenter) {
- this.mainOffset = -this.$refs.title.getBoundingClientRect().width / 2 + 16 + 'px';
- }
+ handleClick: function handleClick(file) {
+ this.handlePreview && this.handlePreview(file);
}
-
- var unwatch = this.$watch('index', function (val) {
- _this.$watch('$parent.active', _this.updateStatus, { immediate: true });
- unwatch();
- });
}
};
/***/ },
-/* 327 */
+/* 279 */
/***/ function(module, exports) {
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-step",
- class: ['is-' + _vm.$parent.direction],
- style: ([_vm.style, _vm.isLast ? '' : {
- marginRight: -_vm.$parent.stepOffset + 'px'
- }])
- }, [_c('div', {
- staticClass: "el-step__head",
- class: ['is-' + _vm.currentStatus, {
- 'is-text': !_vm.icon
- }]
- }, [_c('div', {
- staticClass: "el-step__line",
- class: ['is-' + _vm.$parent.direction, {
- 'is-icon': _vm.icon
- }],
- style: (_vm.isLast ? '' : {
- marginRight: _vm.$parent.stepOffset + 'px'
- })
- }, [_c('i', {
- staticClass: "el-step__line-inner",
- style: (_vm.lineStyle)
- })]), _c('span', {
- staticClass: "el-step__icon"
- }, [(_vm.currentStatus !== 'success' && _vm.currentStatus !== 'error') ? _vm._t("icon", [(_vm.icon) ? _c('i', {
- class: ['el-icon-' + _vm.icon]
- }) : _c('div', [_vm._v(_vm._s(_vm.index + 1))])]) : _c('i', {
- class: ['el-icon-' + (_vm.currentStatus === 'success' ? 'check' : 'close')]
- })], 2)]), _c('div', {
- staticClass: "el-step__main",
- style: ({
- marginLeft: _vm.mainOffset
- })
- }, [_c('div', {
- ref: "title",
- staticClass: "el-step__title",
- class: ['is-' + _vm.currentStatus]
- }, [_vm._t("title", [_vm._v(_vm._s(_vm.title))])], 2), _c('div', {
- staticClass: "el-step__description",
- class: ['is-' + _vm.currentStatus]
- }, [_vm._t("description", [_vm._v(_vm._s(_vm.description))])], 2)])])
- },staticRenderFns: []}
+ module.exports = __webpack_require__(78);
/***/ },
-/* 328 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _main = __webpack_require__(329);
-
- var _main2 = _interopRequireDefault(_main);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _main2.default.install = function (Vue) {
- Vue.component(_main2.default.name, _main2.default);
- };
+/* 280 */
+/***/ function(module, exports) {
- exports.default = _main2.default;
+ module.exports={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, index) {
+ return _c('li', {
+ key: index,
+ class: ['el-upload-list__item', 'is-' + file.status]
+ }, [(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(), (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-view"
+ })]) : _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-delete2"
+ })]) : _vm._e()]) : _vm._e()], 1)
+ }))
+ },staticRenderFns: []}
/***/ },
-/* 329 */
+/* 281 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(330),
+ __webpack_require__(282),
/* template */
- __webpack_require__(331),
+ null,
/* styles */
null,
/* scopeId */
@@ -57763,725 +56934,672 @@ module.exports =
/***/ },
-/* 330 */
+/* 282 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _throttle = __webpack_require__(131);
+ var _ajax = __webpack_require__(283);
- var _throttle2 = _interopRequireDefault(_throttle);
+ var _ajax2 = _interopRequireDefault(_ajax);
- var _resizeEvent = __webpack_require__(110);
+ var _uploadDragger = __webpack_require__(284);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var _uploadDragger2 = _interopRequireDefault(_uploadDragger);
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElCarousel',
-
+ inject: ['uploader'],
+ components: {
+ UploadDragger: _uploadDragger2.default
+ },
props: {
- initialIndex: {
- type: Number,
- default: 0
- },
- height: String,
- trigger: {
+ type: String,
+ action: {
type: String,
- default: 'hover'
- },
- autoplay: {
- type: Boolean,
- default: true
- },
- interval: {
- type: Number,
- default: 3000
- },
- indicatorPosition: String,
- indicator: {
- type: Boolean,
- default: true
+ required: true
},
- arrow: {
+ name: {
type: String,
- default: 'hover'
+ default: 'file'
},
- type: String
- },
-
- data: function data() {
- return {
- items: [],
- activeIndex: -1,
- containerWidth: 0,
- timer: null,
- hover: false
- };
+ 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: _ajax2.default
+ },
+ disabled: Boolean
},
-
- computed: {
- hasLabel: function hasLabel() {
- return this.items.some(function (item) {
- return item.label.toString().length > 0;
- });
- }
+ data: function data() {
+ return {
+ mouseover: false,
+ reqs: {}
+ };
},
- watch: {
- items: function items(val) {
- if (val.length > 0) this.setActiveItem(this.initialIndex);
- },
- activeIndex: function activeIndex(val, oldVal) {
- this.resetItemPosition(oldVal);
- this.$emit('change', val, oldVal);
- },
- autoplay: function autoplay(val) {
- val ? this.startTimer() : this.pauseTimer();
- }
- },
methods: {
- handleMouseEnter: function handleMouseEnter() {
- this.hover = true;
- this.pauseTimer();
- },
- handleMouseLeave: function handleMouseLeave() {
- this.hover = false;
- this.startTimer();
+ isImage: function isImage(str) {
+ return str.indexOf('image') !== -1;
},
- 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;
+ handleChange: function handleChange(ev) {
+ var files = ev.target.files;
+
+ if (!files) return;
+ this.uploadFiles(files);
},
- handleButtonEnter: function handleButtonEnter(arrow) {
+ uploadFiles: function uploadFiles(files) {
var _this = this;
- this.items.forEach(function (item, index) {
- if (arrow === _this.itemInStage(item, index)) {
- item.hover = true;
- }
- });
- },
- handleButtonLeave: function handleButtonLeave() {
- this.items.forEach(function (item) {
- item.hover = false;
- });
- },
- updateItems: function updateItems() {
- this.items = this.$children.filter(function (child) {
- return child.$options.name === 'ElCarouselItem';
+ 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);
});
},
- resetItemPosition: function resetItemPosition(oldIndex) {
+ upload: function upload(rawFile, file) {
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++;
+ 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) {
+ if (Object.prototype.toString.call(processedFile) === '[object File]') {
+ _this2.post(processedFile);
+ } else {
+ _this2.post(rawFile);
+ }
+ }, function () {
+ _this2.onRemove(rawFile, true);
+ });
+ } else if (before !== false) {
+ this.post(rawFile);
} else {
- this.activeIndex = 0;
+ this.onRemove(rawFile, true);
}
},
- pauseTimer: function pauseTimer() {
- clearInterval(this.timer);
- },
- startTimer: function startTimer() {
- if (this.interval <= 0 || !this.autoplay) 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]);
+ 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();
}
- }
- index = Number(index);
- if (isNaN(index) || index !== Math.floor(index)) {
- ("production") !== 'production' && console.warn('[Element Warn][Carousel]index must be an integer.');
- return;
- }
- var length = this.items.length;
- if (index < 0) {
- this.activeIndex = length - 1;
- } else if (index >= length) {
- this.activeIndex = 0;
} else {
- this.activeIndex = index;
+ Object.keys(reqs).forEach(function (uid) {
+ if (reqs[uid]) reqs[uid].abort();
+ delete reqs[uid];
+ });
}
},
- 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;
+ post: function post(rawFile) {
+ var _this3 = this;
- this.throttledArrowClick = (0, _throttle2.default)(300, true, function (index) {
- _this3.setActiveItem(index);
- });
- this.throttledIndicatorHover = (0, _throttle2.default)(300, function (index) {
- _this3.handleIndicatorHover(index);
- });
- },
- mounted: function mounted() {
- var _this4 = this;
+ var uid = rawFile.uid;
- this.updateItems();
- this.$nextTick(function () {
- (0, _resizeEvent.addResizeListener)(_this4.$el, _this4.resetItemPosition);
- if (_this4.initialIndex < _this4.items.length && _this4.initialIndex >= 0) {
- _this4.activeIndex = _this4.initialIndex;
+ 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);
}
- _this4.startTimer();
- });
- },
- beforeDestroy: function beforeDestroy() {
- if (this.$el) (0, _resizeEvent.removeResizeListener)(this.$el, this.resetItemPosition);
- }
- };
-
-/***/ },
-/* 331 */
-/***/ function(module, exports) {
-
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-carousel",
- class: {
- 'el-carousel--card': _vm.type === 'card'
},
- on: {
- "mouseenter": function($event) {
- $event.stopPropagation();
- _vm.handleMouseEnter($event)
- },
- "mouseleave": function($event) {
- $event.stopPropagation();
- _vm.handleMouseLeave($event)
- }
- }
- }, [_c('div', {
- staticClass: "el-carousel__container",
- style: ({
- height: _vm.height
- })
- }, [_c('transition', {
- attrs: {
- "name": "carousel-arrow-left"
- }
- }, [(_vm.arrow !== 'never') ? _c('button', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.arrow === 'always' || _vm.hover),
- expression: "arrow === 'always' || hover"
- }],
- staticClass: "el-carousel__arrow el-carousel__arrow--left",
- 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()]), _c('transition', {
- attrs: {
- "name": "carousel-arrow-right"
- }
- }, [(_vm.arrow !== 'never') ? _c('button', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.arrow === 'always' || _vm.hover),
- expression: "arrow === 'always' || hover"
- }],
- staticClass: "el-carousel__arrow el-carousel__arrow--right",
- on: {
- "mouseenter": function($event) {
- _vm.handleButtonEnter('right')
- },
- "mouseleave": _vm.handleButtonLeave,
- "click": function($event) {
- $event.stopPropagation();
- _vm.throttledArrowClick(_vm.activeIndex + 1)
+ handleClick: function handleClick() {
+ if (!this.disabled) {
+ this.$refs.input.value = null;
+ this.$refs.input.click();
}
}
- }, [_c('i', {
- staticClass: "el-icon-arrow-right"
- })]) : _vm._e()]), _vm._t("default")], 2), (_vm.indicatorPosition !== 'none') ? _c('ul', {
- staticClass: "el-carousel__indicators",
- class: {
- 'el-carousel__indicators--labels': _vm.hasLabel, 'el-carousel__indicators--outside': _vm.indicatorPosition === 'outside' || _vm.type === 'card'
- }
- }, _vm._l((_vm.items), function(item, index) {
- return _c('li', {
- staticClass: "el-carousel__indicator",
+ },
+
+ 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;
+
+ var data = {
class: {
- 'is-active': index === _vm.activeIndex
+ 'el-upload': true
},
on: {
- "mouseenter": function($event) {
- _vm.throttledIndicatorHover(index)
- },
- "click": function($event) {
- $event.stopPropagation();
- _vm.handleIndicatorClick(index)
- }
+ click: handleClick
}
- }, [_c('button', {
- staticClass: "el-carousel__button"
- }, [(_vm.hasLabel) ? _c('span', [_vm._v(_vm._s(item.label))]) : _vm._e()])])
- })) : _vm._e()])
- },staticRenderFns: []}
+ };
+ data.class['el-upload--' + listType] = true;
+ return h(
+ 'div',
+ data,
+ [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
+ }
+ },
+ []
+ )]
+ );
+ }
+ };
/***/ },
-/* 332 */
-/***/ function(module, exports, __webpack_require__) {
+/* 283 */
+/***/ function(module, exports) {
'use strict';
exports.__esModule = true;
+ exports.default = upload;
+ function getError(action, option, xhr) {
+ var msg = void 0;
+ if (xhr.response) {
+ msg = xhr.status + ' ' + (xhr.response.error || xhr.response);
+ } else if (xhr.responseText) {
+ msg = xhr.status + ' ' + xhr.responseText;
+ } else {
+ msg = 'fail to post ' + action + ' ' + xhr.status;
+ }
- var _main = __webpack_require__(333);
-
- var _main2 = _interopRequireDefault(_main);
+ var err = new Error(msg);
+ err.status = xhr.status;
+ err.method = 'post';
+ err.url = action;
+ return err;
+ }
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ function getBody(xhr) {
+ var text = xhr.responseText || xhr.response;
+ if (!text) {
+ return text;
+ }
- /* istanbul ignore next */
- _main2.default.install = function (Vue) {
- Vue.component(_main2.default.name, _main2.default);
- };
+ try {
+ return JSON.parse(text);
+ } catch (e) {
+ return text;
+ }
+ }
- exports.default = _main2.default;
+ function upload(option) {
+ if (typeof XMLHttpRequest === 'undefined') {
+ return;
+ }
-/***/ },
-/* 333 */
-/***/ function(module, exports, __webpack_require__) {
+ var xhr = new XMLHttpRequest();
+ var action = option.action;
- 'use strict';
+ if (xhr.upload) {
+ xhr.upload.onprogress = function progress(e) {
+ if (e.total > 0) {
+ e.percent = e.loaded / e.total * 100;
+ }
+ option.onProgress(e);
+ };
+ }
- exports.__esModule = true;
+ var formData = new FormData();
- var _resizeEvent = __webpack_require__(110);
+ if (option.data) {
+ Object.keys(option.data).map(function (key) {
+ formData.append(key, option.data[key]);
+ });
+ }
- var _scrollbarWidth = __webpack_require__(136);
+ formData.append(option.filename, option.file);
- var _scrollbarWidth2 = _interopRequireDefault(_scrollbarWidth);
+ xhr.onerror = function error(e) {
+ option.onError(e);
+ };
- var _util = __webpack_require__(107);
+ xhr.onload = function onload() {
+ if (xhr.status < 200 || xhr.status >= 300) {
+ return option.onError(getError(action, option, xhr));
+ }
- var _bar = __webpack_require__(334);
+ option.onSuccess(getBody(xhr));
+ };
- var _bar2 = _interopRequireDefault(_bar);
+ xhr.open('post', action, true);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ if (option.withCredentials && 'withCredentials' in xhr) {
+ xhr.withCredentials = true;
+ }
- /* istanbul ignore next */
- // reference https://github.com/noeldelgado/gemini-scrollbar/blob/master/index.js
+ var headers = option.headers || {};
- exports.default = {
- name: 'ElScrollbar',
+ for (var item in headers) {
+ if (headers.hasOwnProperty(item) && headers[item] !== null) {
+ xhr.setRequestHeader(item, headers[item]);
+ }
+ }
+ xhr.send(formData);
+ return xhr;
+ }
- components: { Bar: _bar2.default },
+/***/ },
+/* 284 */
+/***/ function(module, exports, __webpack_require__) {
- props: {
- native: Boolean,
- wrapStyle: {},
- wrapClass: {},
- viewClass: {},
- viewStyle: {},
- noresize: Boolean, // 如果 container 尺寸不会发生变化,最好设置它可以优化性能
- tag: {
- type: String,
- default: 'div'
- }
- },
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(285),
+ /* template */
+ __webpack_require__(286),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- data: function data() {
- return {
- sizeWidth: '0',
- sizeHeight: '0',
- moveX: 0,
- moveY: 0
- };
- },
+ module.exports = Component.exports
- computed: {
- wrap: function wrap() {
- return this.$refs.wrap;
- }
- },
+/***/ },
+/* 285 */
+/***/ function(module, exports) {
- render: function render(h) {
- var gutter = (0, _scrollbarWidth2.default)();
- var style = this.wrapStyle;
+ 'use strict';
- if (gutter) {
- var gutterWith = '-' + gutter + 'px';
- var gutterStyle = 'margin-bottom: ' + gutterWith + '; margin-right: ' + gutterWith + ';';
+ exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- if (Array.isArray(this.wrapStyle)) {
- style = (0, _util.toObject)(this.wrapStyle);
- style.marginRight = style.marginBottom = gutterWith;
- } else if (typeof this.wrapStyle === 'string') {
- style += gutterStyle;
- } else {
- style = gutterStyle;
+ exports.default = {
+ name: 'ElUploadDrag',
+ props: {
+ disabled: Boolean
+ },
+ data: function data() {
+ return {
+ dragover: false
+ };
+ },
+
+ methods: {
+ onDragover: function onDragover() {
+ if (!this.disabled) {
+ this.dragover = true;
+ }
+ },
+ onDrop: function onDrop(e) {
+ if (!this.disabled) {
+ this.dragover = false;
+ this.$emit('file', e.dataTransfer.files);
}
}
- 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;
+/***/ },
+/* 286 */
+/***/ function(module, exports) {
- if (!this.native) {
- nodes = [wrap, h(
- _bar2.default,
- {
- attrs: {
- move: this.moveX,
- size: this.sizeWidth }
- },
- []
- ), h(
- _bar2.default,
- {
- attrs: {
- vertical: true,
- move: this.moveY,
- size: this.sizeHeight }
- },
- []
- )];
- } else {
- nodes = [h(
- 'div',
- {
- ref: 'wrap',
- 'class': [this.wrapClass, 'el-scrollbar__wrap'],
- style: style },
- [[view]]
- )];
+ module.exports={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();
+ _vm.onDrop($event)
+ },
+ "dragover": function($event) {
+ $event.preventDefault();
+ _vm.onDragover($event)
+ },
+ "dragleave": function($event) {
+ $event.preventDefault();
+ _vm.dragover = false
+ }
}
- return h('div', { class: 'el-scrollbar' }, nodes);
- },
-
-
- methods: {
- handleScroll: function handleScroll() {
- var wrap = this.wrap;
+ }, [_vm._t("default")], 2)
+ },staticRenderFns: []}
- 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;
+/***/ },
+/* 287 */
+/***/ function(module, exports, __webpack_require__) {
- heightPercentage = wrap.clientHeight * 100 / wrap.scrollHeight;
- widthPercentage = wrap.clientWidth * 100 / wrap.scrollWidth;
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(288),
+ /* template */
+ null,
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- this.sizeHeight = heightPercentage < 100 ? heightPercentage + '%' : '';
- this.sizeWidth = widthPercentage < 100 ? widthPercentage + '%' : '';
- }
- },
+ module.exports = Component.exports
- mounted: function mounted() {
- if (this.native) return;
- this.$nextTick(this.update);
- !this.noresize && (0, _resizeEvent.addResizeListener)(this.$refs.resize, this.update);
- },
- beforeDestroy: function beforeDestroy() {
- if (this.native) return;
- !this.noresize && (0, _resizeEvent.removeResizeListener)(this.$refs.resize, this.update);
- }
- };
/***/ },
-/* 334 */
+/* 288 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _dom = __webpack_require__(44);
+ var _uploadDragger = __webpack_require__(284);
- var _util = __webpack_require__(335);
+ var _uploadDragger2 = _interopRequireDefault(_uploadDragger);
- /* istanbul ignore next */
- exports.default = {
- name: 'Bar',
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ exports.default = {
+ components: {
+ UploadDragger: _uploadDragger2.default
+ },
props: {
- vertical: Boolean,
- size: String,
- move: Number
+ type: String,
+ data: {},
+ action: {
+ type: String,
+ required: true
+ },
+ name: {
+ type: String,
+ default: 'file'
+ },
+ withCredentials: Boolean,
+ accept: String,
+ onStart: Function,
+ onProgress: Function,
+ onSuccess: Function,
+ onError: Function,
+ beforeUpload: Function,
+ onPreview: {
+ type: Function,
+ default: function _default() {}
+ },
+ onRemove: {
+ type: Function,
+ default: function _default() {}
+ },
+ drag: Boolean,
+ listType: String,
+ disabled: Boolean
},
- computed: {
- bar: function bar() {
- return _util.BAR_MAP[this.vertical ? 'vertical' : 'horizontal'];
+ data: function data() {
+ return {
+ mouseover: false,
+ domain: '',
+ file: null,
+ submitting: false
+ };
+ },
+
+
+ methods: {
+ isImage: function isImage(str) {
+ return str.indexOf('image') !== -1;
},
- wrap: function wrap() {
- return this.$parent.wrap;
+ handleClick: function handleClick() {
+ if (!this.disabled) {
+ this.$refs.input.click();
+ }
+ },
+ handleChange: function handleChange(ev) {
+ var file = ev.target.value;
+ if (file) {
+ this.uploadFiles(file);
+ }
+ },
+ uploadFiles: function uploadFiles(file) {
+ if (this.submitting) return;
+ this.submitting = true;
+ this.file = file;
+ this.onStart(file);
+
+ var formNode = this.getFormNode();
+ var dataSpan = this.getFormDataNode();
+ var data = this.data;
+ if (typeof data === 'function') {
+ data = data(file);
+ }
+ var inputs = [];
+ for (var key in data) {
+ if (data.hasOwnProperty(key)) {
+ inputs.push('');
+ }
+ }
+ dataSpan.innerHTML = inputs.join('');
+ formNode.submit();
+ dataSpan.innerHTML = '';
+ },
+ getFormNode: function getFormNode() {
+ return this.$refs.form;
+ },
+ getFormDataNode: function getFormDataNode() {
+ return this.$refs.data;
}
},
+ created: function created() {
+ this.frameName = 'frame-' + Date.now();
+ },
+ mounted: function mounted() {
+ var self = this;
+ !this.$isServer && window.addEventListener('message', function (event) {
+ if (!self.file) return;
+ var targetOrigin = new URL(self.action).origin;
+ if (event.origin !== targetOrigin) return;
+ var response = event.data;
+ if (response.result === 'success') {
+ self.onSuccess(response, self.file);
+ } else if (response.result === 'failed') {
+ self.onError(response, self.file);
+ }
+ self.submitting = false;
+ self.file = null;
+ }, false);
+ },
render: function render(h) {
- var size = this.size,
- move = this.move,
- bar = this.bar;
+ var drag = this.drag,
+ uploadFiles = this.uploadFiles,
+ listType = this.listType,
+ frameName = this.frameName,
+ disabled = this.disabled;
+ var oClass = { 'el-upload': true };
+ oClass['el-upload--' + listType] = true;
return h(
'div',
{
- 'class': ['el-scrollbar__bar', 'is-' + bar.key],
+ 'class': oClass,
on: {
- 'mousedown': this.clickTrackHandler
+ 'click': this.handleClick
+ },
+ nativeOn: {
+ 'drop': this.onDrop,
+ 'dragover': this.handleDragover,
+ 'dragleave': this.handleDragleave
}
},
[h(
- 'div',
+ 'iframe',
{
- ref: 'thumb',
- 'class': 'el-scrollbar__thumb',
on: {
- 'mousedown': this.clickThumbHandler
+ 'load': this.onload
},
- style: (0, _util.renderThumbStyle)({ size: size, move: move, bar: bar }) },
+ ref: 'iframe',
+ attrs: { name: frameName
+ }
+ },
[]
- )]
- );
- },
-
-
- methods: {
- clickThumbHandler: function clickThumbHandler(e) {
- 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;
-
- (0, _dom.on)(document, 'mousemove', this.mouseMoveDocumentHandler);
- (0, _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];
+ ), h(
+ 'form',
+ { ref: 'form', attrs: { action: this.action, target: frameName, enctype: 'multipart/form-data', method: 'POST' }
+ },
+ [h(
+ 'input',
+ {
+ 'class': 'el-upload__input',
+ attrs: { type: 'file',
- this.wrap[this.bar.scroll] = thumbPositionPercentage * this.wrap[this.bar.scrollSize] / 100;
- },
- mouseUpDocumentHandler: function mouseUpDocumentHandler(e) {
- this.cursorDown = false;
- this[this.bar.axis] = 0;
- (0, _dom.off)(document, 'mousemove', this.mouseMoveDocumentHandler);
- document.onselectstart = null;
- }
- },
+ name: 'file',
- destroyed: function destroyed() {
- (0, _dom.off)(document, 'mouseup', this.mouseUpDocumentHandler);
+ accept: this.accept },
+ ref: 'input', on: {
+ 'change': this.handleChange
+ }
+ },
+ []
+ ), h(
+ 'input',
+ {
+ attrs: { type: 'hidden', name: 'documentDomain', value: this.$isServer ? '' : document.domain }
+ },
+ []
+ ), h(
+ 'span',
+ { ref: 'data' },
+ []
+ )]
+ ), drag ? h(
+ 'upload-dragger',
+ {
+ on: {
+ 'file': uploadFiles
+ },
+ attrs: { disabled: disabled }
+ },
+ [this.$slots.default]
+ ) : this.$slots.default]
+ );
}
};
/***/ },
-/* 335 */
+/* 289 */
/***/ function(module, exports) {
- 'use strict';
-
- exports.__esModule = true;
- exports.renderThumbStyle = renderThumbStyle;
- var BAR_MAP = exports.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;
- };
+ module.exports = __webpack_require__(79);
/***/ },
-/* 336 */
+/* 290 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _item = __webpack_require__(337);
+ var _progress = __webpack_require__(291);
- var _item2 = _interopRequireDefault(_item);
+ var _progress2 = _interopRequireDefault(_progress);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _item2.default.install = function (Vue) {
- Vue.component(_item2.default.name, _item2.default);
+ _progress2.default.install = function (Vue) {
+ Vue.component(_progress2.default.name, _progress2.default);
};
- exports.default = _item2.default;
+ exports.default = _progress2.default;
/***/ },
-/* 337 */
+/* 291 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(338),
+ __webpack_require__(292),
/* template */
- __webpack_require__(339),
+ __webpack_require__(293),
/* styles */
null,
/* scopeId */
@@ -58494,7 +57612,7 @@ module.exports =
/***/ },
-/* 338 */
+/* 292 */
/***/ function(module, exports) {
'use strict';
@@ -58526,160 +57644,201 @@ module.exports =
//
//
//
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var CARD_SCALE = 0.83;
exports.default = {
- name: 'ElCarouselItem',
-
+ name: 'ElProgress',
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;
+ type: {
+ type: String,
+ default: 'line',
+ validator: function validator(val) {
+ return ['line', 'circle'].indexOf(val) > -1;
}
- return index;
},
- calculateTranslate: function calculateTranslate(index, activeIndex, parentWidth) {
- 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;
+ percentage: {
+ type: Number,
+ default: 0,
+ required: true,
+ validator: function validator(val) {
+ return val >= 0 && val <= 100;
}
},
- translateItem: function translateItem(index, activeIndex, oldIndex) {
- var parentWidth = this.$parent.$el.offsetWidth;
- var length = this.$parent.items.length;
- if (this.$parent.type !== 'card' && oldIndex !== undefined) {
- this.animating = index === activeIndex || index === oldIndex;
- }
- if (index !== activeIndex && length > 2) {
- index = this.processIndex(index, activeIndex, length);
+ status: {
+ type: String
+ },
+ strokeWidth: {
+ type: Number,
+ default: 6
+ },
+ textInside: {
+ type: Boolean,
+ default: false
+ },
+ width: {
+ type: Number,
+ default: 126
+ },
+ showText: {
+ type: Boolean,
+ default: true
+ }
+ },
+ computed: {
+ barStyle: function barStyle() {
+ var style = {};
+ style.width = this.percentage + '%';
+ return style;
+ },
+ relativeStrokeWidth: function relativeStrokeWidth() {
+ return (this.strokeWidth / this.width * 100).toFixed(1);
+ },
+ trackPath: function trackPath() {
+ var radius = parseInt(50 - parseFloat(this.relativeStrokeWidth) / 2, 10);
+
+ return 'M 50 50 m 0 -' + radius + ' a ' + radius + ' ' + radius + ' 0 1 1 0 ' + radius * 2 + ' a ' + radius + ' ' + radius + ' 0 1 1 0 -' + radius * 2;
+ },
+ perimeter: function perimeter() {
+ var radius = 50 - parseFloat(this.relativeStrokeWidth) / 2;
+ return 2 * Math.PI * radius;
+ },
+ circlePathStyle: function circlePathStyle() {
+ var perimeter = this.perimeter;
+ return {
+ strokeDasharray: perimeter + 'px,' + perimeter + 'px',
+ strokeDashoffset: (1 - this.percentage / 100) * perimeter + 'px',
+ transition: 'stroke-dashoffset 0.6s ease 0s, stroke 0.6s ease'
+ };
+ },
+ stroke: function stroke() {
+ var ret;
+ switch (this.status) {
+ case 'success':
+ ret = '#13ce66';
+ break;
+ case 'exception':
+ ret = '#ff4949';
+ break;
+ default:
+ ret = '#20a0ff';
}
- if (this.$parent.type === 'card') {
- this.inStage = Math.round(Math.abs(index - activeIndex)) <= 1;
- this.active = index === activeIndex;
- this.translate = this.calculateTranslate(index, activeIndex, parentWidth);
- this.scale = this.active ? 1 : CARD_SCALE;
+ return ret;
+ },
+ iconClass: function iconClass() {
+ if (this.type === 'line') {
+ return this.status === 'success' ? 'el-icon-circle-check' : 'el-icon-circle-cross';
} else {
- this.active = index === activeIndex;
- this.translate = parentWidth * (index - activeIndex);
+ return this.status === 'success' ? 'el-icon-check' : 'el-icon-close';
}
- this.ready = true;
},
- handleItemClick: function handleItemClick() {
- var parent = this.$parent;
- if (parent && parent.type === 'card') {
- var index = parent.items.indexOf(this);
- parent.setActiveItem(index);
- }
+ progressTextSize: function progressTextSize() {
+ return this.type === 'line' ? 12 + this.strokeWidth * 0.4 : this.width * 0.111111 + 2;
}
- },
-
- created: function created() {
- this.$parent && this.$parent.updateItems();
- },
- destroyed: function destroyed() {
- this.$parent && this.$parent.updateItems();
}
};
/***/ },
-/* 339 */
+/* 293 */
/***/ function(module, exports) {
module.exports={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
- },
+ 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,
+ }
+ ]
+ }, [(_vm.type === 'line') ? _c('div', {
+ staticClass: "el-progress-bar"
+ }, [_c('div', {
+ staticClass: "el-progress-bar__outer",
style: ({
- msTransform: ("translateX(" + _vm.translate + "px) scale(" + _vm.scale + ")"),
- webkitTransform: ("translateX(" + _vm.translate + "px) scale(" + _vm.scale + ")"),
- transform: ("translateX(" + _vm.translate + "px) scale(" + _vm.scale + ")")
- }),
- on: {
- "click": _vm.handleItemClick
+ 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.percentage) + "%")]) : _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"
}
- }, [(_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)
+ }, [_c('path', {
+ staticClass: "el-progress-circle__track",
+ 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-linecap": "round",
+ "stroke": _vm.stroke,
+ "stroke-width": _vm.relativeStrokeWidth,
+ "fill": "none"
+ }
+ })])]), (_vm.showText && !_vm.textInside) ? _c('div', {
+ staticClass: "el-progress__text",
+ style: ({
+ fontSize: _vm.progressTextSize + 'px'
+ })
+ }, [(!_vm.status) ? [_vm._v(_vm._s(_vm.percentage) + "%")] : _c('i', {
+ class: _vm.iconClass
+ })], 2) : _vm._e()])
},staticRenderFns: []}
/***/ },
-/* 340 */
+/* 294 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _collapse = __webpack_require__(341);
+ var _spinner = __webpack_require__(295);
- var _collapse2 = _interopRequireDefault(_collapse);
+ var _spinner2 = _interopRequireDefault(_spinner);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _collapse2.default.install = function (Vue) {
- Vue.component(_collapse2.default.name, _collapse2.default);
+ _spinner2.default.install = function (Vue) {
+ Vue.component(_spinner2.default.name, _spinner2.default);
};
- exports.default = _collapse2.default;
+ exports.default = _spinner2.default;
/***/ },
-/* 341 */
+/* 295 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(342),
+ __webpack_require__(296),
/* template */
- __webpack_require__(343),
+ __webpack_require__(297),
/* styles */
null,
/* scopeId */
@@ -58692,7 +57851,7 @@ module.exports =
/***/ },
-/* 342 */
+/* 296 */
/***/ function(module, exports) {
'use strict';
@@ -58703,105 +57862,169 @@ module.exports =
//
//
//
+ //
+ //
exports.default = {
- name: 'ElCollapse',
-
- componentName: 'ElCollapse',
-
+ name: 'ElSpinner',
props: {
- accordion: Boolean,
- value: {
- type: [Array, String, Number],
- default: function _default() {
- return [];
- }
- }
- },
-
- data: function data() {
- return {
- activeNames: [].concat(this.value)
- };
- },
-
-
- 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);
+ type: String,
+ radius: {
+ type: Number,
+ default: 100
},
- 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);
- }
+ strokeWidth: {
+ type: Number,
+ default: 5
+ },
+ strokeColor: {
+ type: String,
+ default: '#efefef'
}
- },
-
- created: function created() {
- this.$on('item-click', this.handleItemClick);
}
};
/***/ },
-/* 343 */
+/* 297 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-collapse"
- }, [_vm._t("default")], 2)
+ 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
+ }
+ })])])
},staticRenderFns: []}
/***/ },
-/* 344 */
+/* 298 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _collapseItem = __webpack_require__(345);
+ var _main = __webpack_require__(299);
- var _collapseItem2 = _interopRequireDefault(_collapseItem);
+ var _main2 = _interopRequireDefault(_main);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- /* istanbul ignore next */
- _collapseItem2.default.install = function (Vue) {
- Vue.component(_collapseItem2.default.name, _collapseItem2.default);
+ exports.default = _main2.default;
+
+/***/ },
+/* 299 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _vue = __webpack_require__(133);
+
+ var _vue2 = _interopRequireDefault(_vue);
+
+ var _popup = __webpack_require__(14);
+
+ var _vdom = __webpack_require__(194);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ var MessageConstructor = _vue2.default.extend(__webpack_require__(300));
+
+ var instance = void 0;
+ var instances = [];
+ var seed = 1;
+
+ var Message = function Message(options) {
+ if (_vue2.default.prototype.$isServer) return;
+ options = options || {};
+ if (typeof options === 'string') {
+ options = {
+ message: options
+ };
+ }
+ var userOnClose = options.onClose;
+ var id = 'message_' + seed++;
+
+ options.onClose = function () {
+ Message.close(id, userOnClose);
+ };
+ instance = new MessageConstructor({
+ data: options
+ });
+ instance.id = id;
+ if ((0, _vdom.isVNode)(instance.message)) {
+ instance.$slots.default = [instance.message];
+ instance.message = null;
+ }
+ instance.vm = instance.$mount();
+ document.body.appendChild(instance.vm.$el);
+ instance.vm.visible = true;
+ instance.dom = instance.vm.$el;
+ instance.dom.style.zIndex = _popup.PopupManager.nextZIndex();
+ instances.push(instance);
+ return instance.vm;
};
- exports.default = _collapseItem2.default;
+ ['success', 'warning', 'info', 'error'].forEach(function (type) {
+ Message[type] = function (options) {
+ if (typeof options === 'string') {
+ options = {
+ message: options
+ };
+ }
+ options.type = type;
+ return Message(options);
+ };
+ });
+
+ Message.close = function (id, userOnClose) {
+ for (var i = 0, len = instances.length; i < len; i++) {
+ if (id === instances[i].id) {
+ if (typeof userOnClose === 'function') {
+ userOnClose(instances[i]);
+ }
+ instances.splice(i, 1);
+ break;
+ }
+ }
+ };
+
+ Message.closeAll = function () {
+ for (var i = instances.length - 1; i >= 0; i--) {
+ instances[i].close();
+ }
+ };
+
+ exports.default = Message;
/***/ },
-/* 345 */
+/* 300 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(346),
+ __webpack_require__(301),
/* template */
- __webpack_require__(347),
+ __webpack_require__(307),
/* styles */
null,
/* scopeId */
@@ -58814,23 +58037,14 @@ module.exports =
/***/ },
-/* 346 */
+/* 301 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
-
- var _collapseTransition = __webpack_require__(49);
-
- var _collapseTransition2 = _interopRequireDefault(_collapseTransition);
-
- var _emitter = __webpack_require__(15);
-
- var _emitter2 = _interopRequireDefault(_emitter);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
+ //
+ //
//
//
//
@@ -58848,93 +58062,171 @@ module.exports =
//
exports.default = {
- name: 'ElCollapseItem',
-
- componentName: 'ElCollapseItem',
-
- mixins: [_emitter2.default],
-
- components: { ElCollapseTransition: _collapseTransition2.default },
-
data: function data() {
return {
- contentWrapStyle: {
- height: 'auto',
- display: 'block'
- },
- contentHeight: 0
+ visible: false,
+ message: '',
+ duration: 3000,
+ type: 'info',
+ iconClass: '',
+ customClass: '',
+ onClose: null,
+ showClose: false,
+ closed: false,
+ timer: null
};
},
- props: {
- title: String,
- name: {
- type: [String, Number],
- default: function _default() {
- return this._uid;
- }
- }
- },
-
computed: {
- isActive: function isActive() {
- return this.$parent.activeNames.indexOf(this.name) > -1;
+ typeImg: function typeImg() {
+ return __webpack_require__(302)("./" + this.type + '.svg');
}
},
watch: {
- 'isActive': function isActive(value) {}
+ closed: function closed(newVal) {
+ if (newVal) {
+ this.visible = false;
+ this.$el.addEventListener('transitionend', this.destroyElement);
+ }
+ }
},
methods: {
- handleHeaderClick: function handleHeaderClick() {
- this.dispatch('ElCollapse', 'item-click', this);
+ destroyElement: function destroyElement() {
+ this.$el.removeEventListener('transitionend', this.destroyElement);
+ 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);
+ }
}
},
- mounted: function mounted() {}
+ mounted: function mounted() {
+ this.startTimer();
+ }
};
/***/ },
-/* 347 */
-/***/ function(module, exports) {
+/* 302 */
+/***/ function(module, exports, __webpack_require__) {
- module.exports={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
+ var map = {
+ "./error.svg": 303,
+ "./info.svg": 304,
+ "./success.svg": 305,
+ "./warning.svg": 306
+ };
+ function webpackContext(req) {
+ return __webpack_require__(webpackContextResolve(req));
+ };
+ function webpackContextResolve(req) {
+ return map[req] || (function() { throw new Error("Cannot find module '" + req + "'.") }());
+ };
+ webpackContext.keys = function webpackContextKeys() {
+ return Object.keys(map);
+ };
+ webpackContext.resolve = webpackContextResolve;
+ module.exports = webpackContext;
+ webpackContext.id = 302;
+
+
+/***/ },
+/* 303 */
+/***/ function(module, exports) {
+
+ module.exports = ""
+
+/***/ },
+/* 304 */
+/***/ function(module, exports) {
+
+ module.exports = ""
+
+/***/ },
+/* 305 */
+/***/ function(module, exports) {
+
+ module.exports = ""
+
+/***/ },
+/* 306 */
+/***/ function(module, exports) {
+
+ module.exports = ""
+
+/***/ },
+/* 307 */
+/***/ function(module, exports) {
+
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('transition', {
+ attrs: {
+ "name": "el-message-fade"
}
}, [_c('div', {
- staticClass: "el-collapse-item__header",
- on: {
- "click": _vm.handleHeaderClick
- }
- }, [_c('i', {
- staticClass: "el-collapse-item__header__arrow el-icon-arrow-right"
- }), _vm._t("title", [_vm._v(_vm._s(_vm.title))])], 2), _c('el-collapse-transition', [_c('div', {
directives: [{
name: "show",
rawName: "v-show",
- value: (_vm.isActive),
- expression: "isActive"
+ value: (_vm.visible),
+ expression: "visible"
}],
- staticClass: "el-collapse-item__wrap"
- }, [_c('div', {
- staticClass: "el-collapse-item__content"
- }, [_vm._t("default")], 2)])])], 1)
+ staticClass: "el-message",
+ class: _vm.customClass,
+ on: {
+ "mouseenter": _vm.clearTimer,
+ "mouseleave": _vm.startTimer
+ }
+ }, [(!_vm.iconClass) ? _c('img', {
+ staticClass: "el-message__img",
+ attrs: {
+ "src": _vm.typeImg,
+ "alt": ""
+ }
+ }) : _vm._e(), _c('div', {
+ staticClass: "el-message__group",
+ class: {
+ 'is-with-icon': _vm.iconClass
+ }
+ }, [_vm._t("default", [_c('p', [(_vm.iconClass) ? _c('i', {
+ staticClass: "el-message__icon",
+ class: _vm.iconClass
+ }) : _vm._e(), _vm._v(_vm._s(_vm.message))])]), (_vm.showClose) ? _c('div', {
+ staticClass: "el-message__closeBtn el-icon-close",
+ on: {
+ "click": _vm.close
+ }
+ }) : _vm._e()], 2)])])
},staticRenderFns: []}
/***/ },
-/* 348 */
+/* 308 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(349);
+ var _main = __webpack_require__(309);
var _main2 = _interopRequireDefault(_main);
@@ -58948,14 +58240,14 @@ module.exports =
exports.default = _main2.default;
/***/ },
-/* 349 */
+/* 309 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(350),
+ __webpack_require__(310),
/* template */
- __webpack_require__(355),
+ __webpack_require__(311),
/* styles */
null,
/* scopeId */
@@ -58968,107 +58260,129 @@ module.exports =
/***/ },
-/* 350 */
-/***/ function(module, exports, __webpack_require__) {
+/* 310 */
+/***/ function(module, exports) {
'use strict';
exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var _vue = __webpack_require__(133);
+ exports.default = {
+ name: 'ElBadge',
- var _vue2 = _interopRequireDefault(_vue);
+ props: {
+ value: {},
+ max: Number,
+ isDot: Boolean,
+ hidden: Boolean
+ },
- var _menu = __webpack_require__(351);
+ computed: {
+ content: function content() {
+ if (this.isDot) return;
- var _menu2 = _interopRequireDefault(_menu);
+ var value = this.value;
+ var max = this.max;
- var _input = __webpack_require__(20);
+ if (typeof value === 'number' && typeof max === 'number') {
+ return max < value ? max + '+' : value;
+ }
- var _input2 = _interopRequireDefault(_input);
+ return value;
+ }
+ }
+ };
- var _vuePopper = __webpack_require__(24);
+/***/ },
+/* 311 */
+/***/ function(module, exports) {
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
+ module.exports={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.isDot)),
+ expression: "!hidden && ( content || isDot )"
+ }],
+ staticClass: "el-badge__content",
+ class: {
+ 'is-fixed': _vm.$slots.default, 'is-dot': _vm.isDot
+ },
+ domProps: {
+ "textContent": _vm._s(_vm.content)
+ }
+ })])], 2)
+ },staticRenderFns: []}
- var _clickoutside = __webpack_require__(21);
+/***/ },
+/* 312 */
+/***/ function(module, exports, __webpack_require__) {
- var _clickoutside2 = _interopRequireDefault(_clickoutside);
+ 'use strict';
- var _emitter = __webpack_require__(15);
+ exports.__esModule = true;
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _main = __webpack_require__(313);
- var _locale = __webpack_require__(10);
+ var _main2 = _interopRequireDefault(_main);
- var _locale2 = _interopRequireDefault(_locale);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var _locale3 = __webpack_require__(111);
+ /* istanbul ignore next */
+ _main2.default.install = function (Vue) {
+ Vue.component(_main2.default.name, _main2.default);
+ };
- var _debounce = __webpack_require__(69);
+ exports.default = _main2.default;
- var _debounce2 = _interopRequireDefault(_debounce);
+/***/ },
+/* 313 */
+/***/ function(module, exports, __webpack_require__) {
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(314),
+ /* template */
+ __webpack_require__(315),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- var popperMixin = {
- props: {
- placement: {
- type: String,
- default: 'bottom-start'
- },
- appendToBody: _vuePopper2.default.props.appendToBody,
- offset: _vuePopper2.default.props.offset,
- boundariesPadding: _vuePopper2.default.props.boundariesPadding,
- popperOptions: _vuePopper2.default.props.popperOptions
- },
- methods: _vuePopper2.default.methods,
- data: _vuePopper2.default.data,
- beforeDestroy: _vuePopper2.default.beforeDestroy
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ module.exports = Component.exports
+
+
+/***/ },
+/* 314 */
+/***/ function(module, exports) {
+
+ 'use strict';
+
+ exports.__esModule = true;
//
//
//
@@ -59082,325 +58396,409 @@ module.exports =
//
exports.default = {
- name: 'ElCascader',
+ name: 'ElCard',
- directives: { Clickoutside: _clickoutside2.default },
+ props: ['header', 'bodyStyle']
+ };
- mixins: [popperMixin, _emitter2.default, _locale2.default],
+/***/ },
+/* 315 */
+/***/ function(module, exports) {
- components: {
- ElInput: _input2.default
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-card"
+ }, [(_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)])
+ },staticRenderFns: []}
+
+/***/ },
+/* 316 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _main = __webpack_require__(317);
+
+ var _main2 = _interopRequireDefault(_main);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _main2.default.install = function (Vue) {
+ Vue.component(_main2.default.name, _main2.default);
+ };
+
+ exports.default = _main2.default;
+
+/***/ },
+/* 317 */
+/***/ function(module, exports, __webpack_require__) {
+
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(318),
+ /* template */
+ __webpack_require__(319),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
+
+ module.exports = Component.exports
+
+
+/***/ },
+/* 318 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _dom = __webpack_require__(44);
+
+ exports.default = {
+ name: 'ElRate',
+
+ data: function data() {
+ return {
+ classMap: {},
+ colorMap: {},
+ pointerAtLeftHalf: true,
+ currentValue: this.value,
+ hoverIndex: -1
+ };
},
+
props: {
- options: {
- type: Array,
- required: true
+ value: {
+ type: Number,
+ default: 0
},
- props: {
- type: Object,
- default: function _default() {
- return {
- children: 'children',
- label: 'label',
- value: 'value',
- disabled: 'disabled'
- };
- }
+ lowThreshold: {
+ type: Number,
+ default: 2
},
- value: {
+ highThreshold: {
+ type: Number,
+ default: 4
+ },
+ max: {
+ type: Number,
+ default: 5
+ },
+ colors: {
type: Array,
default: function _default() {
- return [];
+ return ['#F7BA2A', '#F7BA2A', '#F7BA2A'];
}
},
- placeholder: {
+ voidColor: {
+ type: String,
+ default: '#C6D1DE'
+ },
+ disabledVoidColor: {
type: String,
+ default: '#EFF2F7'
+ },
+ iconClasses: {
+ type: Array,
default: function _default() {
- return (0, _locale3.t)('el.cascader.placeholder');
+ return ['el-icon-star-on', 'el-icon-star-on', 'el-icon-star-on'];
}
},
- disabled: Boolean,
- clearable: {
+ voidIconClass: {
+ type: String,
+ default: 'el-icon-star-off'
+ },
+ disabledVoidIconClass: {
+ type: String,
+ default: 'el-icon-star-on'
+ },
+ disabled: {
type: Boolean,
default: false
},
- changeOnSelect: Boolean,
- popperClass: String,
- expandTrigger: {
- type: String,
- default: 'click'
+ allowHalf: {
+ type: Boolean,
+ default: false
},
- filterable: Boolean,
- size: String,
- showAllLevels: {
+ showText: {
type: Boolean,
- default: true
+ default: false
},
- debounce: {
- type: Number,
- default: 300
+ textColor: {
+ type: String,
+ default: '#1f2d3d'
},
- beforeFilter: {
- type: Function,
+ texts: {
+ type: Array,
default: function _default() {
- return function () {};
+ return ['极差', '失望', '一般', '满意', '惊喜'];
}
+ },
+ textTemplate: {
+ type: String,
+ default: '{value}'
}
},
- data: function data() {
- return {
- currentValue: this.value || [],
- menu: null,
- debouncedInputChange: function debouncedInputChange() {},
-
- menuVisible: false,
- inputHover: false,
- inputValue: '',
- flatOptions: null
- };
- },
-
-
computed: {
- labelKey: function labelKey() {
- return this.props.label || 'label';
+ text: function text() {
+ var result = '';
+ if (this.disabled) {
+ result = this.textTemplate.replace(/\{\s*value\s*\}/, this.value);
+ } else {
+ result = this.texts[Math.ceil(this.currentValue) - 1];
+ }
+ return result;
},
- valueKey: function valueKey() {
- return this.props.value || 'value';
+ decimalStyle: function decimalStyle() {
+ var width = '';
+ if (this.disabled) {
+ width = (this.valueDecimal < 50 ? 0 : 50) + '%';
+ }
+ if (this.allowHalf) {
+ width = '50%';
+ }
+ return {
+ color: this.activeColor,
+ width: width
+ };
},
- childrenKey: function childrenKey() {
- return this.props.children || 'children';
+ valueDecimal: function valueDecimal() {
+ return this.value * 100 - Math.floor(this.value) * 100;
},
- currentLabels: function currentLabels() {
- var _this = this;
-
- var options = this.options;
- var labels = [];
- this.currentValue.forEach(function (value) {
- var targetOption = options && options.filter(function (option) {
- return option[_this.valueKey] === value;
- })[0];
- if (targetOption) {
- labels.push(targetOption[_this.labelKey]);
- options = targetOption[_this.childrenKey];
- }
- });
- return labels;
- }
- },
-
- watch: {
- menuVisible: function menuVisible(value) {
- value ? this.showMenu() : this.hideMenu();
+ decimalIconClass: function decimalIconClass() {
+ return this.getValueFromMap(this.value, this.classMap);
},
- value: function value(_value) {
- this.currentValue = _value;
+ voidClass: function voidClass() {
+ return this.disabled ? this.classMap.disabledVoidClass : this.classMap.voidClass;
},
- currentValue: function currentValue(value) {
- this.dispatch('ElFormItem', 'el.form.change', [value]);
+ activeClass: function activeClass() {
+ return this.getValueFromMap(this.currentValue, this.classMap);
},
-
- options: {
- deep: true,
- handler: function handler(value) {
- if (!this.menu) {
- this.initMenu();
- }
- this.flatOptions = this.flattenOptions(this.options);
- this.menu.options = value;
+ 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;
}
},
- methods: {
- initMenu: function initMenu() {
- this.menu = new _vue2.default(_menu2.default).$mount();
- this.menu.options = this.options;
- this.menu.props = this.props;
- this.menu.expandTrigger = this.expandTrigger;
- this.menu.changeOnSelect = this.changeOnSelect;
- this.menu.popperClass = this.popperClass;
- this.popperElm = this.menu.$el;
- this.menu.$on('pick', this.handlePick);
- this.menu.$on('activeItemChange', this.handleActiveItemChange);
- this.menu.$on('menuLeave', this.doDestroy);
- },
- showMenu: function showMenu() {
- var _this2 = this;
+ watch: {
+ value: function value(val) {
+ this.$emit('change', val);
+ this.currentValue = val;
+ this.pointerAtLeftHalf = this.value !== Math.floor(this.value);
+ }
+ },
- if (!this.menu) {
- this.initMenu();
+ methods: {
+ getValueFromMap: function getValueFromMap(value, map) {
+ var result = '';
+ if (value <= this.lowThreshold) {
+ result = map.lowColor || map.lowClass;
+ } else if (value >= this.highThreshold) {
+ result = map.highColor || map.highClass;
+ } else {
+ result = map.mediumColor || map.mediumClass;
}
-
- this.menu.value = this.currentValue.slice(0);
- this.menu.visible = true;
- this.menu.options = this.options;
- this.$nextTick(function (_) {
- _this2.updatePopper();
- _this2.menu.inputWidth = _this2.$refs.input.$el.offsetWidth - 2;
- });
+ return result;
},
- hideMenu: function hideMenu() {
- this.inputValue = '';
- this.menu.visible = false;
+ showDecimalIcon: function showDecimalIcon(item) {
+ var showWhenDisabled = this.disabled && 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;
},
- handleActiveItemChange: function handleActiveItemChange(value) {
- var _this3 = this;
-
- this.$nextTick(function (_) {
- _this3.updatePopper();
- });
- this.$emit('active-item-change', value);
+ getIconStyle: function getIconStyle(item) {
+ var voidColor = this.disabled ? this.colorMap.disabledVoidColor : this.colorMap.voidColor;
+ return {
+ color: item <= this.currentValue ? this.activeColor : voidColor
+ };
},
- handlePick: function handlePick(value) {
- var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
-
- this.currentValue = value;
- this.$emit('input', value);
- this.$emit('change', value);
-
- if (close) {
- this.menuVisible = false;
+ selectValue: function selectValue(value) {
+ if (this.disabled) {
+ return;
+ }
+ if (this.allowHalf && this.pointerAtLeftHalf) {
+ this.$emit('input', this.currentValue);
} else {
- this.$nextTick(this.updatePopper);
+ this.$emit('input', value);
}
},
- handleInputChange: function handleInputChange(value) {
- var _this4 = this;
-
- if (!this.menuVisible) return;
- var flatOptions = this.flatOptions;
-
- if (!value) {
- this.menu.options = this.options;
- this.$nextTick(this.updatePopper);
+ setCurrentValue: function setCurrentValue(value, event) {
+ if (this.disabled) {
return;
}
-
- var filteredFlatOptions = flatOptions.filter(function (optionsStack) {
- return optionsStack.some(function (option) {
- return new RegExp(value, 'i').test(option[_this4.labelKey]);
- });
- });
-
- if (filteredFlatOptions.length > 0) {
- filteredFlatOptions = filteredFlatOptions.map(function (optionStack) {
- return {
- __IS__FLAT__OPTIONS: true,
- value: optionStack.map(function (item) {
- return item[_this4.valueKey];
- }),
- label: _this4.renderFilteredOptionLabel(value, optionStack)
- };
- });
+ /* istanbul ignore if */
+ if (this.allowHalf) {
+ var target = event.target;
+ if ((0, _dom.hasClass)(target, 'el-rate__item')) {
+ target = target.querySelector('.el-rate__icon');
+ }
+ if ((0, _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 {
- filteredFlatOptions = [{
- __IS__FLAT__OPTIONS: true,
- label: this.t('el.cascader.noMatch'),
- value: '',
- disabled: true
- }];
+ this.currentValue = value;
}
- this.menu.options = filteredFlatOptions;
- this.$nextTick(this.updatePopper);
- },
- renderFilteredOptionLabel: function renderFilteredOptionLabel(inputValue, optionsStack) {
- var _this5 = this;
-
- return optionsStack.map(function (option, index) {
- var label = option[_this5.labelKey];
- var keywordIndex = label.toLowerCase().indexOf(inputValue.toLowerCase());
- var labelPart = label.slice(keywordIndex, inputValue.length + keywordIndex);
- var node = keywordIndex > -1 ? _this5.highlightKeyword(label, labelPart) : label;
- return index === 0 ? node : [' / ', node];
- });
- },
- highlightKeyword: function highlightKeyword(label, keyword) {
- var _this6 = this;
-
- var h = this._c;
- return label.split(keyword).map(function (node, index) {
- return index === 0 ? node : [h('span', { class: { 'el-cascader-menu__item__keyword': true } }, [_this6._v(keyword)]), node];
- });
- },
- flattenOptions: function flattenOptions(options) {
- var _this7 = this;
-
- var ancestor = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
-
- var flatOptions = [];
- options.forEach(function (option) {
- var optionsStack = ancestor.concat(option);
- if (!option[_this7.childrenKey]) {
- flatOptions.push(optionsStack);
- } else {
- if (_this7.changeOnSelect) {
- flatOptions.push(optionsStack);
- }
- flatOptions = flatOptions.concat(_this7.flattenOptions(option[_this7.childrenKey], optionsStack));
- }
- });
- return flatOptions;
- },
- clearValue: function clearValue(ev) {
- ev.stopPropagation();
- this.handlePick([], true);
- },
- handleClickoutside: function handleClickoutside() {
- this.menuVisible = false;
+ this.hoverIndex = value;
},
- handleClick: function handleClick() {
- if (this.disabled) return;
- if (this.filterable) {
- this.menuVisible = true;
- this.$refs.input.$refs.input.focus();
+ resetCurrentValue: function resetCurrentValue() {
+ if (this.disabled) {
return;
}
- this.menuVisible = !this.menuVisible;
+ if (this.allowHalf) {
+ this.pointerAtLeftHalf = this.value !== Math.floor(this.value);
+ }
+ this.currentValue = this.value;
+ this.hoverIndex = -1;
}
},
created: function created() {
- var _this8 = this;
+ if (!this.value) {
+ this.$emit('input', 0);
+ }
+ this.classMap = {
+ lowClass: this.iconClasses[0],
+ mediumClass: this.iconClasses[1],
+ highClass: this.iconClasses[2],
+ voidClass: this.voidIconClass,
+ disabledVoidClass: this.disabledVoidIconClass
+ };
+ this.colorMap = {
+ lowColor: this.colors[0],
+ mediumColor: this.colors[1],
+ highColor: this.colors[2],
+ voidColor: this.voidColor,
+ disabledVoidColor: this.disabledVoidColor
+ };
+ }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- this.debouncedInputChange = (0, _debounce2.default)(this.debounce, function (value) {
- var before = _this8.beforeFilter(value);
+/***/ },
+/* 319 */
+/***/ function(module, exports) {
- if (before && before.then) {
- _this8.menu.options = [{
- __IS__FLAT__OPTIONS: true,
- label: _this8.t('el.cascader.loading'),
- value: '',
- disabled: true
- }];
- before.then(function () {
- _this8.$nextTick(function () {
- _this8.handleInputChange(value);
- });
- });
- } else if (before !== false) {
- _this8.$nextTick(function () {
- _this8.handleInputChange(value);
- });
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-rate"
+ }, [_vm._l((_vm.max), function(item) {
+ return _c('span', {
+ staticClass: "el-rate__item",
+ style: ({
+ cursor: _vm.disabled ? 'auto' : 'pointer'
+ }),
+ on: {
+ "mousemove": function($event) {
+ _vm.setCurrentValue(item, $event)
+ },
+ "mouseleave": _vm.resetCurrentValue,
+ "click": function($event) {
+ _vm.selectValue(item)
+ }
}
- });
- },
- mounted: function mounted() {
- this.flatOptions = this.flattenOptions(this.options);
- }
+ }, [_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) ? _c('span', {
+ staticClass: "el-rate__text",
+ style: ({
+ color: _vm.textColor
+ })
+ }, [_vm._v(_vm._s(_vm.text))]) : _vm._e()], 2)
+ },staticRenderFns: []}
+
+/***/ },
+/* 320 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _steps = __webpack_require__(321);
+
+ var _steps2 = _interopRequireDefault(_steps);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _steps2.default.install = function (Vue) {
+ Vue.component(_steps2.default.name, _steps2.default);
};
+ exports.default = _steps2.default;
+
/***/ },
-/* 351 */
+/* 321 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(352),
+ __webpack_require__(322),
/* template */
- null,
+ __webpack_require__(323),
/* styles */
null,
/* scopeId */
@@ -59413,358 +58811,350 @@ module.exports =
/***/ },
-/* 352 */
-/***/ function(module, exports, __webpack_require__) {
+/* 322 */
+/***/ function(module, exports) {
'use strict';
exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var _babelHelperVueJsxMergeProps = __webpack_require__(353);
-
- var _babelHelperVueJsxMergeProps2 = _interopRequireDefault(_babelHelperVueJsxMergeProps);
-
- var _shared = __webpack_require__(354);
-
- var _scrollIntoView = __webpack_require__(112);
-
- var _scrollIntoView2 = _interopRequireDefault(_scrollIntoView);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ exports.default = {
+ name: 'ElSteps',
- var copyArray = function copyArray(arr, props) {
- if (!arr || !Array.isArray(arr) || !props) return arr;
- var result = [];
- var configurableProps = ['__IS__FLAT__OPTIONS', 'label', 'value', 'disabled'];
- var childrenProp = props.children || 'children';
- arr.forEach(function (item) {
- var itemCopy = {};
- configurableProps.forEach(function (prop) {
- var propName = props[prop] || prop;
- var value = item[propName];
- if (value !== undefined) itemCopy[propName] = value;
- });
- if (Array.isArray(item[childrenProp])) {
- itemCopy[childrenProp] = copyArray(item[childrenProp], props);
+ props: {
+ space: [Number, String],
+ active: Number,
+ direction: {
+ type: String,
+ default: 'horizontal'
+ },
+ alignCenter: Boolean,
+ center: Boolean,
+ finishStatus: {
+ type: String,
+ default: 'finish'
+ },
+ processStatus: {
+ type: String,
+ default: 'process'
}
- result.push(itemCopy);
- });
- return result;
- };
-
- exports.default = {
- name: 'ElCascaderMenu',
+ },
data: function data() {
return {
- inputWidth: 0,
- options: [],
- props: {},
- visible: false,
- activeValue: [],
- value: [],
- expandTrigger: 'click',
- changeOnSelect: false,
- popperClass: ''
+ steps: [],
+ stepOffset: 0
};
},
watch: {
- visible: function visible(value) {
- if (value) {
- this.activeValue = this.value;
- }
+ active: function active(newVal, oldVal) {
+ this.$emit('change', newVal, oldVal);
},
+ steps: function steps(_steps) {
+ var _this = this;
- value: {
- immediate: true,
- handler: function handler(value) {
- this.activeValue = value;
+ _steps.forEach(function (child, index) {
+ child.index = index;
+ });
+ if (this.center) {
+ (function () {
+ var len = _steps.length;
+ _this.$nextTick(function () {
+ _this.stepOffset = _steps[len - 1].$el.getBoundingClientRect().width / (len - 1);
+ });
+ })();
}
}
- },
+ }
+ };
- computed: {
- activeOptions: {
- cache: false,
- get: function get() {
- var _this = this;
+/***/ },
+/* 323 */
+/***/ function(module, exports) {
- var activeValue = this.activeValue;
- var configurableProps = ['label', 'value', 'children', 'disabled'];
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-steps",
+ class: ['is-' + _vm.direction, _vm.center ? 'is-center' : '']
+ }, [_vm._t("default")], 2)
+ },staticRenderFns: []}
- var formatOptions = function formatOptions(options) {
- options.forEach(function (option) {
- if (option.__IS__FLAT__OPTIONS) return;
- configurableProps.forEach(function (prop) {
- var value = option[_this.props[prop] || prop];
- if (value !== undefined) option[prop] = value;
- });
- if (Array.isArray(option.children)) {
- formatOptions(option.children);
- }
- });
- };
+/***/ },
+/* 324 */
+/***/ function(module, exports, __webpack_require__) {
- var loadActiveOptions = function loadActiveOptions(options) {
- var activeOptions = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
+ 'use strict';
- var level = activeOptions.length;
- activeOptions[level] = options;
- var active = activeValue[level];
- if ((0, _shared.isDef)(active)) {
- options = options.filter(function (option) {
- return option.value === active;
- })[0];
- if (options && options.children) {
- loadActiveOptions(options.children, activeOptions);
- }
- }
- return activeOptions;
- };
+ exports.__esModule = true;
- var optionsCopy = copyArray(this.options, this.props);
- formatOptions(optionsCopy);
- return loadActiveOptions(optionsCopy);
- }
- }
- },
+ var _step = __webpack_require__(325);
- methods: {
- select: function select(item, menuIndex) {
- if (item.__IS__FLAT__OPTIONS) {
- this.activeValue = item.value;
- } else if (menuIndex) {
- this.activeValue.splice(menuIndex, this.activeValue.length - 1, item.value);
- } else {
- this.activeValue = [item.value];
- }
- this.$emit('pick', this.activeValue.slice());
- },
- handleMenuLeave: function handleMenuLeave() {
- this.$emit('menuLeave');
+ var _step2 = _interopRequireDefault(_step);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _step2.default.install = function (Vue) {
+ Vue.component(_step2.default.name, _step2.default);
+ };
+
+ exports.default = _step2.default;
+
+/***/ },
+/* 325 */
+/***/ function(module, exports, __webpack_require__) {
+
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(326),
+ /* template */
+ __webpack_require__(327),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
+
+ module.exports = Component.exports
+
+
+/***/ },
+/* 326 */
+/***/ function(module, exports) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+ exports.default = {
+ name: 'ElStep',
+
+ props: {
+ title: String,
+ icon: String,
+ description: String,
+ status: String
+ },
+
+ data: function data() {
+ return {
+ index: -1,
+ lineStyle: {},
+ mainOffset: 0,
+ 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;
},
- activeItem: function activeItem(item, menuIndex) {
- var len = this.activeOptions.length;
- this.activeValue.splice(menuIndex, len, item.value);
- this.activeOptions.splice(menuIndex + 1, len, item.children);
- if (this.changeOnSelect) {
- this.$emit('pick', this.activeValue.slice(), false);
- } else {
- this.$emit('activeItemChange', this.activeValue);
- }
+ prevStatus: function prevStatus() {
+ var prevStep = this.$parent.steps[this.index - 1];
+ return prevStep ? prevStep.currentStatus : 'wait';
},
- scrollMenu: function scrollMenu(menu) {
- (0, _scrollIntoView2.default)(menu, menu.getElementsByClassName('is-active')[0]);
+
+ isLast: function isLast() {
+ var parent = this.$parent;
+ return parent.steps[parent.steps.length - 1] === this;
},
- handleMenuEnter: function handleMenuEnter() {
- var _this2 = this;
+ style: function style() {
+ var parent = this.$parent;
+ var isCenter = parent.center;
+ var len = parent.steps.length;
- this.$nextTick(function () {
- return _this2.$refs.menus.forEach(function (menu) {
- return _this2.scrollMenu(menu);
- });
- });
+ if (isCenter && this.isLast) {
+ return {};
+ }
+
+ var space = typeof parent.space === 'number' ? parent.space + 'px' : parent.space ? parent.space : 100 / (isCenter ? len - 1 : len) + '%';
+ if (parent.direction === 'horizontal') {
+ return { width: space };
+ } else {
+ if (!this.isLast) {
+ return { height: space };
+ }
+ }
}
},
- render: function render(h) {
- var _this3 = this;
+ methods: {
+ updateStatus: function updateStatus(val) {
+ var prevChild = this.$parent.$children[this.index - 1];
- var activeValue = this.activeValue,
- activeOptions = this.activeOptions,
- visible = this.visible,
- expandTrigger = this.expandTrigger,
- popperClass = this.popperClass;
+ 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' ? 50 : 0;
+ } else if (status === 'wait') {
+ step = 0;
+ style.transitionDelay = -150 * this.index + 'ms';
+ }
- var menus = this._l(activeOptions, function (menu, menuIndex) {
- var isFlat = false;
- var items = _this3._l(menu, function (item) {
- var events = {
- on: {}
- };
+ style.borderWidth = step ? '1px' : 0;
+ this.$parent.direction === 'vertical' ? style.height = step + '%' : style.width = step + '%';
- if (item.__IS__FLAT__OPTIONS) isFlat = true;
+ this.lineStyle = style;
+ }
+ },
- if (!item.disabled) {
- if (item.children) {
- var triggerEvent = {
- click: 'click',
- hover: 'mouseenter'
- }[expandTrigger];
- events.on[triggerEvent] = function () {
- _this3.activeItem(item, menuIndex);
- _this3.$nextTick(function () {
- // adjust self and next level
- _this3.scrollMenu(_this3.$refs.menus[menuIndex]);
- _this3.scrollMenu(_this3.$refs.menus[menuIndex + 1]);
- });
- };
- } else {
- events.on.click = function () {
- _this3.select(item, menuIndex);
- _this3.$nextTick(function () {
- return _this3.scrollMenu(_this3.$refs.menus[menuIndex]);
- });
- };
- }
- }
+ mounted: function mounted() {
+ var _this = this;
- return h(
- 'li',
- (0, _babelHelperVueJsxMergeProps2.default)([{
- 'class': {
- 'el-cascader-menu__item': true,
- 'el-cascader-menu__item--extensible': item.children,
- 'is-active': item.value === activeValue[menuIndex],
- 'is-disabled': item.disabled
- }
- }, events]),
- [item.label]
- );
- });
- var menuStyle = {};
- if (isFlat) {
- menuStyle.minWidth = _this3.inputWidth + 'px';
+ var parent = this.$parent;
+
+ if (parent.direction === 'horizontal') {
+ if (parent.alignCenter) {
+ this.mainOffset = -this.$refs.title.getBoundingClientRect().width / 2 + 16 + 'px';
}
+ }
- return h(
- 'ul',
- {
- 'class': {
- 'el-cascader-menu': true,
- 'el-cascader-menu--flexible': isFlat
- },
- style: menuStyle,
- refInFor: true,
- ref: 'menus' },
- [items]
- );
+ var unwatch = this.$watch('index', function (val) {
+ _this.$watch('$parent.active', _this.updateStatus, { immediate: true });
+ unwatch();
});
- return h(
- 'transition',
- {
- attrs: { name: 'el-zoom-in-top' },
- on: {
- 'before-enter': this.handleMenuEnter,
- 'after-leave': this.handleMenuLeave
- }
- },
- [h(
- 'div',
- {
- directives: [{
- name: 'show',
- value: visible
- }],
-
- 'class': ['el-cascader-menus', popperClass],
- ref: 'wrapper'
- },
- [menus]
- )]
- );
}
};
/***/ },
-/* 353 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(79);
-
-/***/ },
-/* 354 */
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(80);
-
-/***/ },
-/* 355 */
+/* 327 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('span', {
- directives: [{
- name: "clickoutside",
- rawName: "v-clickoutside",
- value: (_vm.handleClickoutside),
- expression: "handleClickoutside"
- }],
- ref: "reference",
- staticClass: "el-cascader",
- class: [{
- 'is-opened': _vm.menuVisible,
- 'is-disabled': _vm.disabled
- },
- _vm.size ? 'el-cascader--' + _vm.size : ''
- ],
- on: {
- "click": _vm.handleClick,
- "mouseenter": function($event) {
- _vm.inputHover = true
- },
- "mouseleave": function($event) {
- _vm.inputHover = false
- }
- }
- }, [_c('el-input', {
- ref: "input",
- attrs: {
- "readonly": !_vm.filterable,
- "placeholder": _vm.currentLabels.length ? undefined : _vm.placeholder,
- "validate-event": false,
- "size": _vm.size,
- "disabled": _vm.disabled
- },
- on: {
- "change": _vm.debouncedInputChange
- },
- model: {
- value: (_vm.inputValue),
- callback: function($$v) {
- _vm.inputValue = $$v
- },
- expression: "inputValue"
- }
- }, [_c('template', {
- slot: "icon"
- }, [(_vm.clearable && _vm.inputHover && _vm.currentLabels.length) ? _c('i', {
- key: "1",
- staticClass: "el-input__icon el-icon-circle-close el-cascader__clearIcon",
- on: {
- "click": _vm.clearValue
- }
- }) : _c('i', {
- key: "2",
- staticClass: "el-input__icon el-icon-caret-bottom",
- class: {
- 'is-reverse': _vm.menuVisible
- }
- })])], 2), _c('span', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.inputValue === ''),
- expression: "inputValue === ''"
+ return _c('div', {
+ staticClass: "el-step",
+ class: ['is-' + _vm.$parent.direction],
+ style: ([_vm.style, _vm.isLast ? '' : {
+ marginRight: -_vm.$parent.stepOffset + 'px'
+ }])
+ }, [_c('div', {
+ staticClass: "el-step__head",
+ class: ['is-' + _vm.currentStatus, {
+ 'is-text': !_vm.icon
+ }]
+ }, [_c('div', {
+ staticClass: "el-step__line",
+ class: ['is-' + _vm.$parent.direction, {
+ 'is-icon': _vm.icon
}],
- staticClass: "el-cascader__label"
- }, [(_vm.showAllLevels) ? [_vm._l((_vm.currentLabels), function(label, index) {
- return [_vm._v("\n " + _vm._s(label) + "\n "), (index < _vm.currentLabels.length - 1) ? _c('span', [_vm._v(" / ")]) : _vm._e()]
- })] : [_vm._v("\n " + _vm._s(_vm.currentLabels[_vm.currentLabels.length - 1]) + "\n ")]], 2)], 1)
+ style: (_vm.isLast ? '' : {
+ marginRight: _vm.$parent.stepOffset + 'px'
+ })
+ }, [_c('i', {
+ staticClass: "el-step__line-inner",
+ style: (_vm.lineStyle)
+ })]), _c('span', {
+ staticClass: "el-step__icon"
+ }, [(_vm.currentStatus !== 'success' && _vm.currentStatus !== 'error') ? _vm._t("icon", [(_vm.icon) ? _c('i', {
+ class: ['el-icon-' + _vm.icon]
+ }) : _c('div', [_vm._v(_vm._s(_vm.index + 1))])]) : _c('i', {
+ class: ['el-icon-' + (_vm.currentStatus === 'success' ? 'check' : 'close')]
+ })], 2)]), _c('div', {
+ staticClass: "el-step__main",
+ style: ({
+ marginLeft: _vm.mainOffset
+ })
+ }, [_c('div', {
+ ref: "title",
+ staticClass: "el-step__title",
+ class: ['is-' + _vm.currentStatus]
+ }, [_vm._t("title", [_vm._v(_vm._s(_vm.title))])], 2), _c('div', {
+ staticClass: "el-step__description",
+ class: ['is-' + _vm.currentStatus]
+ }, [_vm._t("description", [_vm._v(_vm._s(_vm.description))])], 2)])])
},staticRenderFns: []}
/***/ },
-/* 356 */
+/* 328 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(357);
+ var _main = __webpack_require__(329);
var _main2 = _interopRequireDefault(_main);
@@ -59778,14 +59168,14 @@ module.exports =
exports.default = _main2.default;
/***/ },
-/* 357 */
+/* 329 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(358),
+ __webpack_require__(330),
/* template */
- __webpack_require__(373),
+ __webpack_require__(331),
/* styles */
null,
/* scopeId */
@@ -59798,522 +59188,725 @@ module.exports =
/***/ },
-/* 358 */
+/* 330 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _color = __webpack_require__(359);
-
- var _color2 = _interopRequireDefault(_color);
-
- var _pickerDropdown = __webpack_require__(360);
-
- var _pickerDropdown2 = _interopRequireDefault(_pickerDropdown);
+ var _throttle = __webpack_require__(131);
- var _clickoutside = __webpack_require__(21);
+ var _throttle2 = _interopRequireDefault(_throttle);
- var _clickoutside2 = _interopRequireDefault(_clickoutside);
+ var _resizeEvent = __webpack_require__(110);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
exports.default = {
- name: 'ElColorPicker',
+ name: 'ElCarousel',
props: {
- value: {
- type: String
+ initialIndex: {
+ type: Number,
+ default: 0
},
- showAlpha: {
- type: Boolean
+ height: String,
+ trigger: {
+ type: String,
+ default: 'hover'
},
- colorFormat: {
- type: String
- }
- },
-
- directives: { Clickoutside: _clickoutside2.default },
+ autoplay: {
+ type: Boolean,
+ default: true
+ },
+ interval: {
+ type: Number,
+ default: 3000
+ },
+ indicatorPosition: String,
+ indicator: {
+ type: Boolean,
+ default: true
+ },
+ arrow: {
+ type: String,
+ default: 'hover'
+ },
+ type: String
+ },
- computed: {
- displayedColor: function displayedColor() {
- if (!this.value && !this.showPanelColor) {
- return 'transparent';
- } else {
- var _color$toRgb = this.color.toRgb(),
- r = _color$toRgb.r,
- g = _color$toRgb.g,
- b = _color$toRgb.b;
+ data: function data() {
+ return {
+ items: [],
+ activeIndex: -1,
+ containerWidth: 0,
+ timer: null,
+ hover: false
+ };
+ },
- return this.showAlpha ? 'rgba(' + r + ', ' + g + ', ' + b + ', ' + this.color.get('alpha') / 100 + ')' : 'rgb(' + r + ', ' + g + ', ' + b + ')';
- }
+
+ computed: {
+ hasLabel: function hasLabel() {
+ return this.items.some(function (item) {
+ return item.label.toString().length > 0;
+ });
}
},
watch: {
- value: function value(val) {
- if (!val) {
- this.showPanelColor = false;
- } else if (val && val !== this.color.value) {
- this.color.fromString(val);
- }
+ items: function items(val) {
+ if (val.length > 0) this.setActiveItem(this.initialIndex);
},
-
- color: {
- deep: true,
- handler: function handler() {
- this.showPanelColor = true;
- }
+ activeIndex: function activeIndex(val, oldVal) {
+ this.resetItemPosition(oldVal);
+ this.$emit('change', val, oldVal);
},
- displayedColor: function displayedColor(val) {
- this.$emit('active-change', val);
+ autoplay: function autoplay(val) {
+ val ? this.startTimer() : this.pauseTimer();
}
},
methods: {
- confirmValue: function confirmValue(value) {
- this.$emit('input', this.color.value);
- this.$emit('change', this.color.value);
- this.showPicker = false;
+ handleMouseEnter: function handleMouseEnter() {
+ this.hover = true;
+ this.pauseTimer();
},
- clearValue: function clearValue() {
- this.$emit('input', null);
- this.$emit('change', null);
- this.showPanelColor = false;
- this.showPicker = false;
- this.resetColor();
+ handleMouseLeave: function handleMouseLeave() {
+ this.hover = false;
+ this.startTimer();
},
- hide: function hide() {
- this.showPicker = false;
- this.resetColor();
+ 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;
},
- resetColor: function resetColor() {
+ handleButtonEnter: function handleButtonEnter(arrow) {
var _this = this;
- this.$nextTick(function (_) {
- if (_this.value) {
- _this.color.fromString(_this.value);
- } else {
- _this.showPanelColor = false;
+ this.items.forEach(function (item, index) {
+ if (arrow === _this.itemInStage(item, index)) {
+ item.hover = true;
}
});
- }
- },
+ },
+ handleButtonLeave: function handleButtonLeave() {
+ 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;
- mounted: function mounted() {
- var value = this.value;
- if (value) {
- this.color.fromString(value);
+ 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 {
+ this.activeIndex = 0;
+ }
+ },
+ pauseTimer: function pauseTimer() {
+ clearInterval(this.timer);
+ },
+ startTimer: function startTimer() {
+ if (this.interval <= 0 || !this.autoplay) 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)) {
+ ("production") !== 'production' && console.warn('[Element Warn][Carousel]index must be an integer.');
+ return;
+ }
+ var length = this.items.length;
+ if (index < 0) {
+ this.activeIndex = length - 1;
+ } else if (index >= length) {
+ this.activeIndex = 0;
+ } else {
+ this.activeIndex = index;
+ }
+ },
+ 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;
+ }
}
- this.popperElm = this.$refs.dropdown.$el;
},
- data: function data() {
- var color = new _color2.default({
- enableAlpha: this.showAlpha,
- format: this.colorFormat
+
+ created: function created() {
+ var _this3 = this;
+
+ this.throttledArrowClick = (0, _throttle2.default)(300, true, function (index) {
+ _this3.setActiveItem(index);
+ });
+ this.throttledIndicatorHover = (0, _throttle2.default)(300, function (index) {
+ _this3.handleIndicatorHover(index);
});
- return {
- color: color,
- showPicker: false,
- showPanelColor: false
- };
},
+ mounted: function mounted() {
+ var _this4 = this;
-
- components: {
- PickerDropdown: _pickerDropdown2.default
+ this.updateItems();
+ this.$nextTick(function () {
+ (0, _resizeEvent.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) (0, _resizeEvent.removeResizeListener)(this.$el, this.resetItemPosition);
}
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ };
/***/ },
-/* 359 */
+/* 331 */
/***/ function(module, exports) {
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-carousel",
+ class: {
+ 'el-carousel--card': _vm.type === 'card'
+ },
+ on: {
+ "mouseenter": function($event) {
+ $event.stopPropagation();
+ _vm.handleMouseEnter($event)
+ },
+ "mouseleave": function($event) {
+ $event.stopPropagation();
+ _vm.handleMouseLeave($event)
+ }
+ }
+ }, [_c('div', {
+ staticClass: "el-carousel__container",
+ style: ({
+ height: _vm.height
+ })
+ }, [_c('transition', {
+ attrs: {
+ "name": "carousel-arrow-left"
+ }
+ }, [(_vm.arrow !== 'never') ? _c('button', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.arrow === 'always' || _vm.hover),
+ expression: "arrow === 'always' || hover"
+ }],
+ staticClass: "el-carousel__arrow el-carousel__arrow--left",
+ 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()]), _c('transition', {
+ attrs: {
+ "name": "carousel-arrow-right"
+ }
+ }, [(_vm.arrow !== 'never') ? _c('button', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.arrow === 'always' || _vm.hover),
+ expression: "arrow === 'always' || hover"
+ }],
+ staticClass: "el-carousel__arrow el-carousel__arrow--right",
+ 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', {
+ staticClass: "el-carousel__indicators",
+ class: {
+ 'el-carousel__indicators--labels': _vm.hasLabel, 'el-carousel__indicators--outside': _vm.indicatorPosition === 'outside' || _vm.type === 'card'
+ }
+ }, _vm._l((_vm.items), function(item, index) {
+ return _c('li', {
+ staticClass: "el-carousel__indicator",
+ class: {
+ '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()])])
+ })) : _vm._e()])
+ },staticRenderFns: []}
+
+/***/ },
+/* 332 */
+/***/ function(module, exports, __webpack_require__) {
+
'use strict';
exports.__esModule = true;
- 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; };
+ var _main = __webpack_require__(333);
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+ var _main2 = _interopRequireDefault(_main);
- var hsv2hsl = function hsv2hsl(hue, sat, val) {
- return [hue, sat * val / ((hue = (2 - sat) * val) < 1 ? hue : 2 - hue) || 0, hue / 2];
- };
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- // Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1
- //
- var isOnePointZero = function isOnePointZero(n) {
- return typeof n === 'string' && n.indexOf('.') !== -1 && parseFloat(n) === 1;
+ /* istanbul ignore next */
+ _main2.default.install = function (Vue) {
+ Vue.component(_main2.default.name, _main2.default);
};
- var isPercentage = function isPercentage(n) {
- return typeof n === 'string' && n.indexOf('%') !== -1;
- };
+ exports.default = _main2.default;
- // Take input from [0, n] and return it as [0, 1]
- var bound01 = function bound01(value, max) {
- if (isOnePointZero(value)) value = '100%';
+/***/ },
+/* 333 */
+/***/ function(module, exports, __webpack_require__) {
- var processPercent = isPercentage(value);
- value = Math.min(max, Math.max(0, parseFloat(value)));
+ 'use strict';
- // Automatically convert percentage into number
- if (processPercent) {
- value = parseInt(value * max, 10) / 100;
- }
+ exports.__esModule = true;
- // Handle floating point rounding errors
- if (Math.abs(value - max) < 0.000001) {
- return 1;
- }
+ var _resizeEvent = __webpack_require__(110);
- // Convert into [0, 1] range if it isn't already
- return value % max / parseFloat(max);
- };
+ var _scrollbarWidth = __webpack_require__(136);
- var INT_HEX_MAP = { 10: 'A', 11: 'B', 12: 'C', 13: 'D', 14: 'E', 15: 'F' };
+ var _scrollbarWidth2 = _interopRequireDefault(_scrollbarWidth);
- var toHex = function toHex(_ref) {
- var r = _ref.r,
- g = _ref.g,
- b = _ref.b;
+ var _util = __webpack_require__(107);
- 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);
- };
+ var _bar = __webpack_require__(334);
- if (isNaN(r) || isNaN(g) || isNaN(b)) return '';
+ var _bar2 = _interopRequireDefault(_bar);
- return '#' + hexOne(r) + hexOne(g) + hexOne(b);
- };
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var HEX_INT_MAP = { A: 10, B: 11, C: 12, D: 13, E: 14, F: 15 };
+ /* istanbul ignore next */
+ // reference https://github.com/noeldelgado/gemini-scrollbar/blob/master/index.js
- 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]);
- }
+ exports.default = {
+ name: 'ElScrollbar',
- return HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1];
- };
+ components: { Bar: _bar2.default },
- 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;
+ props: {
+ native: Boolean,
+ wrapStyle: {},
+ wrapClass: {},
+ viewClass: {},
+ viewStyle: {},
+ noresize: Boolean, // 如果 container 尺寸不会发生变化,最好设置它可以优化性能
+ tag: {
+ type: String,
+ default: 'div'
+ }
+ },
- 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);
+ data: function data() {
+ return {
+ sizeWidth: '0',
+ sizeHeight: '0',
+ moveX: 0,
+ moveY: 0
+ };
+ },
- 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);
+ computed: {
+ wrap: function wrap() {
+ return this.$refs.wrap;
+ }
+ },
- var max = Math.max(r, g, b);
- var min = Math.min(r, g, b);
- var h = void 0,
- s = void 0;
- var v = max;
+ render: function render(h) {
+ var gutter = (0, _scrollbarWidth2.default)();
+ var style = this.wrapStyle;
- var d = max - min;
- s = max === 0 ? 0 : d / max;
+ if (gutter) {
+ var gutterWith = '-' + gutter + 'px';
+ var gutterStyle = 'margin-bottom: ' + gutterWith + '; margin-right: ' + gutterWith + ';';
- 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;
+ if (Array.isArray(this.wrapStyle)) {
+ style = (0, _util.toObject)(this.wrapStyle);
+ style.marginRight = style.marginBottom = gutterWith;
+ } else if (typeof this.wrapStyle === 'string') {
+ style += gutterStyle;
+ } else {
+ style = gutterStyle;
+ }
}
- h /= 6;
- }
+ 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
+ },
- 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];
+ 'class': [this.wrapClass, 'el-scrollbar__wrap', gutter ? '' : 'el-scrollbar__wrap--hidden-default'] },
+ [[view]]
+ );
+ var nodes = void 0;
- return {
- r: Math.round(r * 255),
- g: Math.round(g * 255),
- b: Math.round(b * 255)
- };
- };
+ if (!this.native) {
+ nodes = [wrap, h(
+ _bar2.default,
+ {
+ attrs: {
+ move: this.moveX,
+ size: this.sizeWidth }
+ },
+ []
+ ), h(
+ _bar2.default,
+ {
+ 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);
+ },
- var Color = function () {
- function Color(options) {
- _classCallCheck(this, Color);
- this._hue = 0;
- this._saturation = 100;
- this._value = 100;
- this._alpha = 100;
+ methods: {
+ handleScroll: function handleScroll() {
+ var wrap = this.wrap;
- this.enableAlpha = false;
- this.format = 'hex';
- this.value = '';
+ 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;
- options = options || {};
+ heightPercentage = wrap.clientHeight * 100 / wrap.scrollHeight;
+ widthPercentage = wrap.clientWidth * 100 / wrap.scrollWidth;
- for (var option in options) {
- if (options.hasOwnProperty(option)) {
- this[option] = options[option];
- }
+ this.sizeHeight = heightPercentage < 100 ? heightPercentage + '%' : '';
+ this.sizeWidth = widthPercentage < 100 ? widthPercentage + '%' : '';
}
+ },
- this.doOnChange();
+ mounted: function mounted() {
+ if (this.native) return;
+ this.$nextTick(this.update);
+ !this.noresize && (0, _resizeEvent.addResizeListener)(this.$refs.resize, this.update);
+ },
+ beforeDestroy: function beforeDestroy() {
+ if (this.native) return;
+ !this.noresize && (0, _resizeEvent.removeResizeListener)(this.$refs.resize, this.update);
}
+ };
- Color.prototype.set = function set(prop, value) {
- if (arguments.length === 1 && (typeof prop === 'undefined' ? 'undefined' : _typeof(prop)) === 'object') {
- for (var p in prop) {
- if (prop.hasOwnProperty(p)) {
- this.set(p, prop[p]);
- }
- }
+/***/ },
+/* 334 */
+/***/ function(module, exports, __webpack_require__) {
- return;
- }
+ 'use strict';
- this['_' + prop] = value;
- this.doOnChange();
- };
+ exports.__esModule = true;
- Color.prototype.get = function get(prop) {
- return this['_' + prop];
- };
+ var _dom = __webpack_require__(44);
- Color.prototype.toRgb = function toRgb() {
- return hsv2rgb(this._hue, this._saturation, this._value);
- };
+ var _util = __webpack_require__(335);
- Color.prototype.fromString = function fromString(value) {
- var _this = this;
+ /* istanbul ignore next */
+ exports.default = {
+ name: 'Bar',
- if (!value) {
- this._hue = 0;
- this._saturation = 100;
- this._value = 100;
+ props: {
+ vertical: Boolean,
+ size: String,
+ move: Number
+ },
- this.doOnChange();
- return;
+ computed: {
+ bar: function bar() {
+ return _util.BAR_MAP[this.vertical ? 'vertical' : 'horizontal'];
+ },
+ wrap: function wrap() {
+ return this.$parent.wrap;
}
+ },
- var fromHSV = function fromHSV(h, s, v) {
- _this._hue = h;
- _this._saturation = s;
- _this._value = v;
+ render: function render(h) {
+ var size = this.size,
+ move = this.move,
+ bar = this.bar;
- _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);
- });
+ 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
+ },
- if (parts.length === 4) {
- this._alpha = Math.floor(parseFloat(parts[3]) * 100);
- }
- if (parts.length >= 3) {
- var _hsl2hsv = hsl2hsv(parts[0], parts[1], parts[2]),
- h = _hsl2hsv.h,
- s = _hsl2hsv.s,
- v = _hsl2hsv.v;
+ style: (0, _util.renderThumbStyle)({ size: size, move: move, bar: bar }) },
+ []
+ )]
+ );
+ },
- 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);
- }
- 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);
- });
+ methods: {
+ clickThumbHandler: function clickThumbHandler(e) {
+ 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];
- if (_parts2.length === 4) {
- this._alpha = Math.floor(parseFloat(_parts2[3]) * 100);
- }
- if (_parts2.length >= 3) {
- var _rgb2hsv = rgb2hsv(_parts2[0], _parts2[1], _parts2[2]),
- _h = _rgb2hsv.h,
- _s = _rgb2hsv.s,
- _v = _rgb2hsv.v;
+ this.wrap[this.bar.scroll] = thumbPositionPercentage * this.wrap[this.bar.scrollSize] / 100;
+ },
+ startDrag: function startDrag(e) {
+ e.stopImmediatePropagation();
+ this.cursorDown = true;
- fromHSV(_h, _s, _v);
- }
- } else if (value.indexOf('#') !== -1) {
- var hex = value.replace('#', '').trim();
- var r = void 0,
- g = void 0,
- b = void 0;
+ (0, _dom.on)(document, 'mousemove', this.mouseMoveDocumentHandler);
+ (0, _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 (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) {
- r = parseHexChannel(hex.substring(0, 2));
- g = parseHexChannel(hex.substring(2, 4));
- b = parseHexChannel(hex.substring(4));
- }
+ if (!prevPage) return;
- var _rgb2hsv2 = rgb2hsv(r, g, b),
- _h2 = _rgb2hsv2.h,
- _s2 = _rgb2hsv2.s,
- _v2 = _rgb2hsv2.v;
+ 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];
- fromHSV(_h2, _s2, _v2);
+ this.wrap[this.bar.scroll] = thumbPositionPercentage * this.wrap[this.bar.scrollSize] / 100;
+ },
+ mouseUpDocumentHandler: function mouseUpDocumentHandler(e) {
+ this.cursorDown = false;
+ this[this.bar.axis] = 0;
+ (0, _dom.off)(document, 'mousemove', this.mouseMoveDocumentHandler);
+ document.onselectstart = null;
}
- };
+ },
- Color.prototype.doOnChange = function doOnChange() {
- var _hue = this._hue,
- _saturation = this._saturation,
- _value = this._value,
- _alpha = this._alpha,
- format = this.format;
+ destroyed: function destroyed() {
+ (0, _dom.off)(document, 'mouseup', this.mouseUpDocumentHandler);
+ }
+ };
+/***/ },
+/* 335 */
+/***/ function(module, exports) {
- 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;
+ 'use strict';
- 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;
+ exports.__esModule = true;
+ exports.renderThumbStyle = renderThumbStyle;
+ var BAR_MAP = exports.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'
+ }
+ };
- this.value = 'rgb(' + _r + ', ' + _g + ', ' + _b + ')';
- break;
- default:
- this.value = toHex(hsv2rgb(_hue, _saturation, _value));
- }
- }
- };
+ function renderThumbStyle(_ref) {
+ var move = _ref.move,
+ size = _ref.size,
+ bar = _ref.bar;
- return Color;
- }();
+ var style = {};
+ var translate = 'translate' + bar.axis + '(' + move + '%)';
- exports.default = Color;
- ;
+ style[bar.size] = size;
+ style.transform = translate;
+ style.msTransform = translate;
+ style.webkitTransform = translate;
+
+ return style;
+ };
/***/ },
-/* 360 */
+/* 336 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _item = __webpack_require__(337);
+
+ var _item2 = _interopRequireDefault(_item);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _item2.default.install = function (Vue) {
+ Vue.component(_item2.default.name, _item2.default);
+ };
+
+ exports.default = _item2.default;
+
+/***/ },
+/* 337 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(361),
+ __webpack_require__(338),
/* template */
- __webpack_require__(372),
+ __webpack_require__(339),
/* styles */
null,
/* scopeId */
@@ -60326,91 +59919,20 @@ module.exports =
/***/ },
-/* 361 */
-/***/ function(module, exports, __webpack_require__) {
+/* 338 */
+/***/ function(module, exports) {
'use strict';
exports.__esModule = true;
-
- var _svPanel = __webpack_require__(362);
-
- var _svPanel2 = _interopRequireDefault(_svPanel);
-
- var _hueSlider = __webpack_require__(366);
-
- var _hueSlider2 = _interopRequireDefault(_hueSlider);
-
- var _alphaSlider = __webpack_require__(369);
-
- var _alphaSlider2 = _interopRequireDefault(_alphaSlider);
-
- var _vuePopper = __webpack_require__(24);
-
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
-
- var _locale = __webpack_require__(10);
-
- var _locale2 = _interopRequireDefault(_locale);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = {
- name: 'el-color-picker-dropdown',
-
- mixins: [_vuePopper2.default, _locale2.default],
-
- components: {
- SvPanel: _svPanel2.default,
- HueSlider: _hueSlider2.default,
- AlphaSlider: _alphaSlider2.default
- },
-
- props: {
- color: {
- required: true
- },
- showAlpha: Boolean
- },
-
- computed: {
- currentColor: function currentColor() {
- var parent = this.$parent;
- return !parent.value && !parent.showPanelColor ? '' : parent.color.value;
- }
- },
-
- methods: {
- confirmValue: function confirmValue() {
- this.$emit('pick');
- }
- },
-
- 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();
- });
- }
- }
- }
- }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
//
//
//
@@ -60430,227 +59952,159 @@ module.exports =
//
//
-/***/ },
-/* 362 */
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(5)(
- /* script */
- __webpack_require__(363),
- /* template */
- __webpack_require__(365),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
-
-/***/ },
-/* 363 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _draggable = __webpack_require__(364);
-
- var _draggable2 = _interopRequireDefault(_draggable);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = {
- name: 'el-sl-panel',
+ var CARD_SCALE = 0.83;
+ exports.default = {
+ name: 'ElCarouselItem',
props: {
- color: {
- required: true
+ name: String,
+ label: {
+ type: [String, Number],
+ default: ''
}
},
- computed: {
- colorValue: function colorValue() {
- var hue = this.color.get('hue');
- var value = this.color.get('value');
- return { hue: hue, value: value };
- }
+ data: function data() {
+ return {
+ hover: false,
+ translate: 0,
+ scale: 1,
+ active: false,
+ ready: false,
+ inStage: false,
+ animating: false
+ };
},
- 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 _el$getBoundingClient = el.getBoundingClientRect(),
- width = _el$getBoundingClient.width,
- height = _el$getBoundingClient.height;
-
- if (!height) height = width * 3 / 4;
-
- this.cursorLeft = saturation * width / 100;
- this.cursorTop = (100 - value) * height / 100;
-
- this.background = 'hsl(' + this.color.get('hue') + ', 100%, 50%)';
+ 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;
},
- 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
- });
+ calculateTranslate: function calculateTranslate(index, activeIndex, parentWidth) {
+ 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;
+ }
+ },
+ translateItem: function translateItem(index, activeIndex, oldIndex) {
+ var parentWidth = this.$parent.$el.offsetWidth;
+ var length = this.$parent.items.length;
+ if (this.$parent.type !== 'card' && oldIndex !== undefined) {
+ this.animating = index === activeIndex || index === oldIndex;
+ }
+ if (index !== activeIndex && length > 2) {
+ index = this.processIndex(index, activeIndex, length);
+ }
+ if (this.$parent.type === 'card') {
+ this.inStage = Math.round(Math.abs(index - activeIndex)) <= 1;
+ this.active = index === activeIndex;
+ this.translate = this.calculateTranslate(index, activeIndex, parentWidth);
+ this.scale = this.active ? 1 : CARD_SCALE;
+ } else {
+ this.active = index === activeIndex;
+ this.translate = parentWidth * (index - activeIndex);
+ }
+ this.ready = true;
+ },
+ handleItemClick: function handleItemClick() {
+ var parent = this.$parent;
+ if (parent && parent.type === 'card') {
+ var index = parent.items.indexOf(this);
+ parent.setActiveItem(index);
+ }
}
},
- mounted: function mounted() {
- var _this = this;
-
- (0, _draggable2.default)(this.$el, {
- drag: function drag(event) {
- _this.handleDrag(event);
- },
- end: function end(event) {
- _this.handleDrag(event);
- }
- });
-
- this.update();
+ created: function created() {
+ this.$parent && this.$parent.updateItems();
},
- data: function data() {
- return {
- cursorTop: 0,
- cursorLeft: 0,
- background: 'hsl(0, 100%, 50%)'
- };
+ destroyed: function destroyed() {
+ this.$parent && this.$parent.updateItems();
}
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ };
/***/ },
-/* 364 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
+/* 339 */
+/***/ function(module, exports) {
- exports.default = function (element, options) {
- if (_vue2.default.prototype.$isServer) return;
- var moveFn = function moveFn(event) {
- if (options.drag) {
- options.drag(event);
+ module.exports={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: ({
+ msTransform: ("translateX(" + _vm.translate + "px) scale(" + _vm.scale + ")"),
+ webkitTransform: ("translateX(" + _vm.translate + "px) scale(" + _vm.scale + ")"),
+ transform: ("translateX(" + _vm.translate + "px) scale(" + _vm.scale + ")")
+ }),
+ on: {
+ "click": _vm.handleItemClick
}
- };
- var upFn = function upFn(event) {
- document.removeEventListener('mousemove', moveFn);
- document.removeEventListener('mouseup', upFn);
- document.onselectstart = null;
- document.ondragstart = null;
-
- isDragging = false;
+ }, [(_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)
+ },staticRenderFns: []}
- if (options.end) {
- options.end(event);
- }
- };
- element.addEventListener('mousedown', function (event) {
- if (isDragging) return;
- document.onselectstart = function () {
- return false;
- };
- document.ondragstart = function () {
- return false;
- };
+/***/ },
+/* 340 */
+/***/ function(module, exports, __webpack_require__) {
- document.addEventListener('mousemove', moveFn);
- document.addEventListener('mouseup', upFn);
- isDragging = true;
+ 'use strict';
- if (options.start) {
- options.start(event);
- }
- });
- };
+ exports.__esModule = true;
- var _vue = __webpack_require__(133);
+ var _collapse = __webpack_require__(341);
- var _vue2 = _interopRequireDefault(_vue);
+ var _collapse2 = _interopRequireDefault(_collapse);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var isDragging = false;
-
-/***/ },
-/* 365 */
-/***/ function(module, exports) {
+ /* istanbul ignore next */
+ _collapse2.default.install = function (Vue) {
+ Vue.component(_collapse2.default.name, _collapse2.default);
+ };
- module.exports={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')])])
- },staticRenderFns: []}
+ exports.default = _collapse2.default;
/***/ },
-/* 366 */
+/* 341 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(367),
+ __webpack_require__(342),
/* template */
- __webpack_require__(368),
+ __webpack_require__(343),
/* styles */
null,
/* scopeId */
@@ -60663,176 +60117,116 @@ module.exports =
/***/ },
-/* 367 */
-/***/ function(module, exports, __webpack_require__) {
+/* 342 */
+/***/ function(module, exports) {
'use strict';
exports.__esModule = true;
-
- var _draggable = __webpack_require__(364);
-
- var _draggable2 = _interopRequireDefault(_draggable);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ //
+ //
+ //
+ //
+ //
exports.default = {
- name: 'el-color-hue-slider',
+ name: 'ElCollapse',
- props: {
- color: {
- required: true
- },
+ componentName: 'ElCollapse',
- vertical: Boolean
+ props: {
+ accordion: Boolean,
+ value: {
+ type: [Array, String, Number],
+ default: function _default() {
+ return [];
+ }
+ }
},
data: function data() {
return {
- thumbLeft: 0,
- thumbTop: 0
+ activeNames: [].concat(this.value)
};
},
- computed: {
- hueValue: function hueValue() {
- var hue = this.color.get('hue');
- return hue;
- }
- },
-
watch: {
- hueValue: function hueValue() {
- this.update();
+ value: function value(_value) {
+ this.activeNames = [].concat(_value);
}
},
methods: {
- handleClick: function handleClick(event) {
- var thumb = this.$refs.thumb;
- var target = event.target;
-
- if (target !== thumb) {
- this.handleDrag(event);
- }
+ 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);
},
- 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);
+ 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 top = event.clientY - rect.top;
- top = Math.min(top, rect.height - thumb.offsetHeight / 2);
- top = Math.max(thumb.offsetHeight / 2, top);
+ var activeNames = this.activeNames.slice(0);
+ var index = activeNames.indexOf(item.name);
- hue = Math.round((top - thumb.offsetHeight / 2) / (rect.height - thumb.offsetHeight) * 360);
+ if (index > -1) {
+ activeNames.splice(index, 1);
+ } else {
+ activeNames.push(item.name);
+ }
+ this.setActiveNames(activeNames);
}
-
- 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);
- }
- };
-
- (0, _draggable2.default)(bar, dragConfig);
- (0, _draggable2.default)(thumb, dragConfig);
- this.update();
+ created: function created() {
+ this.$on('item-click', this.handleItemClick);
}
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ };
/***/ },
-/* 368 */
+/* 343 */
/***/ function(module, exports) {
module.exports={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'
- })
- })])
+ staticClass: "el-collapse"
+ }, [_vm._t("default")], 2)
},staticRenderFns: []}
/***/ },
-/* 369 */
+/* 344 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _collapseItem = __webpack_require__(345);
+
+ var _collapseItem2 = _interopRequireDefault(_collapseItem);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _collapseItem2.default.install = function (Vue) {
+ Vue.component(_collapseItem2.default.name, _collapseItem2.default);
+ };
+
+ exports.default = _collapseItem2.default;
+
+/***/ },
+/* 345 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(370),
+ __webpack_require__(346),
/* template */
- __webpack_require__(371),
+ __webpack_require__(347),
/* styles */
null,
/* scopeId */
@@ -60845,306 +60239,127 @@ module.exports =
/***/ },
-/* 370 */
+/* 346 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _draggable = __webpack_require__(364);
+ var _collapseTransition = __webpack_require__(49);
- var _draggable2 = _interopRequireDefault(_draggable);
+ var _collapseTransition2 = _interopRequireDefault(_collapseTransition);
+
+ var _emitter = __webpack_require__(15);
+
+ var _emitter2 = _interopRequireDefault(_emitter);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
exports.default = {
- name: 'el-color-alpha-slider',
+ name: 'ElCollapseItem',
- props: {
- color: {
- required: true
- },
- vertical: Boolean
- },
+ componentName: 'ElCollapseItem',
- 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);
+ mixins: [_emitter2.default],
- 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;
+ components: { ElCollapseTransition: _collapseTransition2.default },
- 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;
+ data: function data() {
+ return {
+ contentWrapStyle: {
+ height: 'auto',
+ display: 'block'
+ },
+ contentHeight: 0
+ };
+ },
- 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%)';
+ props: {
+ title: String,
+ name: {
+ type: [String, Number],
+ default: function _default() {
+ return this._uid;
}
- 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
- };
+ computed: {
+ isActive: function isActive() {
+ return this.$parent.activeNames.indexOf(this.name) > -1;
+ }
},
- mounted: function mounted() {
- var _this = this;
-
- var _$refs = this.$refs,
- bar = _$refs.bar,
- thumb = _$refs.thumb;
+ watch: {
+ 'isActive': function isActive(value) {}
+ },
- var dragConfig = {
- drag: function drag(event) {
- _this.handleDrag(event);
- },
- end: function end(event) {
- _this.handleDrag(event);
- }
- };
+ methods: {
+ handleHeaderClick: function handleHeaderClick() {
+ this.dispatch('ElCollapse', 'item-click', this);
+ }
+ },
- (0, _draggable2.default)(bar, dragConfig);
- (0, _draggable2.default)(thumb, dragConfig);
- this.update();
- }
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ mounted: function mounted() {}
+ };
/***/ },
-/* 371 */
+/* 347 */
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
return _c('div', {
- staticClass: "el-color-alpha-slider",
+ staticClass: "el-collapse-item",
class: {
- 'is-vertical': _vm.vertical
+ 'is-active': _vm.isActive
}
}, [_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'
- })
- })])
- },staticRenderFns: []}
-
-/***/ },
-/* 372 */
-/***/ function(module, exports) {
-
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('transition', {
- attrs: {
- "name": "el-zoom-in-top"
- },
+ staticClass: "el-collapse-item__header",
on: {
- "after-leave": _vm.doDestroy
+ "click": _vm.handleHeaderClick
}
- }, [_c('div', {
+ }, [_c('i', {
+ staticClass: "el-collapse-item__header__arrow el-icon-arrow-right"
+ }), _vm._t("title", [_vm._v(_vm._s(_vm.title))])], 2), _c('el-collapse-transition', [_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(), _c('div', {
- staticClass: "el-color-dropdown__btns"
- }, [_c('span', {
- staticClass: "el-color-dropdown__value"
- }, [_vm._v(_vm._s(_vm.currentColor))]), _c('a', {
- staticClass: "el-color-dropdown__link-btn",
- attrs: {
- "href": "JavaScript:"
- },
- on: {
- "click": function($event) {
- _vm.$emit('clear')
- }
- }
- }, [_vm._v(_vm._s(_vm.t('el.colorpicker.clear')))]), _c('button', {
- staticClass: "el-color-dropdown__btn",
- on: {
- "click": _vm.confirmValue
- }
- }, [_vm._v(_vm._s(_vm.t('el.colorpicker.confirm')))])])], 1)])
- },staticRenderFns: []}
-
-/***/ },
-/* 373 */
-/***/ function(module, exports) {
-
- module.exports={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"
+ value: (_vm.isActive),
+ expression: "isActive"
}],
- staticClass: "el-color-picker"
+ staticClass: "el-collapse-item__wrap"
}, [_c('div', {
- staticClass: "el-color-picker__trigger",
- on: {
- "click": function($event) {
- _vm.showPicker = !_vm.showPicker
- }
- }
- }, [_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', {
- staticClass: "el-color-picker__icon el-icon-caret-bottom"
- })]), _c('picker-dropdown', {
- ref: "dropdown",
- staticClass: "el-color-picker__panel",
- attrs: {
- "color": _vm.color,
- "show-alpha": _vm.showAlpha
- },
- on: {
- "pick": _vm.confirmValue,
- "clear": _vm.clearValue
- },
- model: {
- value: (_vm.showPicker),
- callback: function($$v) {
- _vm.showPicker = $$v
- },
- expression: "showPicker"
- }
- })], 1)
+ staticClass: "el-collapse-item__content"
+ }, [_vm._t("default")], 2)])])], 1)
},staticRenderFns: []}
/***/ },
-/* 374 */
+/* 348 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(375);
+ var _main = __webpack_require__(349);
var _main2 = _interopRequireDefault(_main);
@@ -61158,14 +60373,14 @@ module.exports =
exports.default = _main2.default;
/***/ },
-/* 375 */
+/* 349 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(376),
+ __webpack_require__(350),
/* template */
- __webpack_require__(380),
+ __webpack_require__(355),
/* styles */
null,
/* scopeId */
@@ -61178,16 +60393,32 @@ module.exports =
/***/ },
-/* 376 */
+/* 350 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _button = __webpack_require__(31);
+ var _vue = __webpack_require__(133);
- var _button2 = _interopRequireDefault(_button);
+ var _vue2 = _interopRequireDefault(_vue);
+
+ var _menu = __webpack_require__(351);
+
+ var _menu2 = _interopRequireDefault(_menu);
+
+ var _input = __webpack_require__(20);
+
+ var _input2 = _interopRequireDefault(_input);
+
+ var _vuePopper = __webpack_require__(24);
+
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
+
+ var _clickoutside = __webpack_require__(21);
+
+ var _clickoutside2 = _interopRequireDefault(_clickoutside);
var _emitter = __webpack_require__(15);
@@ -61197,12 +60428,42 @@ module.exports =
var _locale2 = _interopRequireDefault(_locale);
- var _transferPanel = __webpack_require__(377);
+ var _locale3 = __webpack_require__(111);
- var _transferPanel2 = _interopRequireDefault(_transferPanel);
+ var _debounce = __webpack_require__(69);
+
+ var _debounce2 = _interopRequireDefault(_debounce);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ var popperMixin = {
+ props: {
+ placement: {
+ type: String,
+ default: 'bottom-start'
+ },
+ appendToBody: _vuePopper2.default.props.appendToBody,
+ offset: _vuePopper2.default.props.offset,
+ boundariesPadding: _vuePopper2.default.props.boundariesPadding,
+ popperOptions: _vuePopper2.default.props.popperOptions
+ },
+ methods: _vuePopper2.default.methods,
+ data: _vuePopper2.default.data,
+ beforeDestroy: _vuePopper2.default.beforeDestroy
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
//
//
//
@@ -61246,150 +60507,325 @@ module.exports =
//
exports.default = {
- name: 'ElTransfer',
+ name: 'ElCascader',
- mixins: [_emitter2.default, _locale2.default],
+ directives: { Clickoutside: _clickoutside2.default },
+
+ mixins: [popperMixin, _emitter2.default, _locale2.default],
components: {
- TransferPanel: _transferPanel2.default,
- ElButton: _button2.default
+ ElInput: _input2.default
},
props: {
- data: {
+ options: {
type: Array,
- default: function _default() {
- return [];
- }
+ required: true
},
- titles: {
- type: Array,
+ props: {
+ type: Object,
default: function _default() {
- return [];
+ return {
+ children: 'children',
+ label: 'label',
+ value: 'value',
+ disabled: 'disabled'
+ };
}
},
- buttonTexts: {
+ value: {
type: Array,
default: function _default() {
return [];
}
},
- filterPlaceholder: {
+ placeholder: {
type: String,
- default: ''
- },
- filterMethod: Function,
- leftDefaultChecked: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- rightDefaultChecked: {
- type: Array,
default: function _default() {
- return [];
+ return (0, _locale3.t)('el.cascader.placeholder');
}
},
- renderContent: Function,
- value: {
- type: Array,
- default: function _default() {
- return [];
- }
+ disabled: Boolean,
+ clearable: {
+ type: Boolean,
+ default: false
},
- footerFormat: {
- type: Object,
- default: function _default() {
- return {};
- }
+ changeOnSelect: Boolean,
+ popperClass: String,
+ expandTrigger: {
+ type: String,
+ default: 'click'
},
filterable: Boolean,
- props: {
- type: Object,
+ size: String,
+ showAllLevels: {
+ type: Boolean,
+ default: true
+ },
+ debounce: {
+ type: Number,
+ default: 300
+ },
+ beforeFilter: {
+ type: Function,
default: function _default() {
- return {
- label: 'label',
- key: 'key',
- disabled: 'disabled'
- };
+ return function () {};
}
}
},
data: function data() {
return {
- leftChecked: [],
- rightChecked: []
+ currentValue: this.value || [],
+ menu: null,
+ debouncedInputChange: function debouncedInputChange() {},
+
+ menuVisible: false,
+ inputHover: false,
+ inputValue: '',
+ flatOptions: null
};
},
computed: {
- sourceData: function sourceData() {
- var _this = this;
-
- return this.data.filter(function (item) {
- return _this.value.indexOf(item[_this.props.key]) === -1;
- });
+ labelKey: function labelKey() {
+ return this.props.label || 'label';
},
- targetData: function targetData() {
- var _this2 = this;
+ valueKey: function valueKey() {
+ return this.props.value || 'value';
+ },
+ childrenKey: function childrenKey() {
+ return this.props.children || 'children';
+ },
+ currentLabels: function currentLabels() {
+ var _this = this;
- return this.data.filter(function (item) {
- return _this2.value.indexOf(item[_this2.props.key]) > -1;
+ var options = this.options;
+ var labels = [];
+ this.currentValue.forEach(function (value) {
+ var targetOption = options && options.filter(function (option) {
+ return option[_this.valueKey] === value;
+ })[0];
+ if (targetOption) {
+ labels.push(targetOption[_this.labelKey]);
+ options = targetOption[_this.childrenKey];
+ }
});
+ return labels;
}
},
watch: {
- value: function value(val) {
- this.dispatch('ElFormItem', 'el.form.change', val);
- }
- },
-
- methods: {
- onSourceCheckedChange: function onSourceCheckedChange(val) {
- this.leftChecked = val;
+ menuVisible: function menuVisible(value) {
+ value ? this.showMenu() : this.hideMenu();
},
- onTargetCheckedChange: function onTargetCheckedChange(val) {
- this.rightChecked = val;
+ value: function value(_value) {
+ this.currentValue = _value;
},
- 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);
+ currentValue: function currentValue(value) {
+ this.dispatch('ElFormItem', 'el.form.change', [value]);
},
- addToRight: function addToRight() {
- var _this3 = this;
- var currentValue = this.value.slice();
- this.leftChecked.forEach(function (item) {
- if (_this3.value.indexOf(item) === -1) {
- currentValue = currentValue.concat(item);
+ options: {
+ deep: true,
+ handler: function handler(value) {
+ if (!this.menu) {
+ this.initMenu();
}
- });
- this.$emit('input', currentValue);
- this.$emit('change', currentValue, 'right', this.leftChecked);
+ this.flatOptions = this.flattenOptions(this.options);
+ this.menu.options = value;
+ }
}
+ },
+
+ methods: {
+ initMenu: function initMenu() {
+ this.menu = new _vue2.default(_menu2.default).$mount();
+ this.menu.options = this.options;
+ this.menu.props = this.props;
+ this.menu.expandTrigger = this.expandTrigger;
+ this.menu.changeOnSelect = this.changeOnSelect;
+ this.menu.popperClass = this.popperClass;
+ this.popperElm = this.menu.$el;
+ this.menu.$on('pick', this.handlePick);
+ this.menu.$on('activeItemChange', this.handleActiveItemChange);
+ this.menu.$on('menuLeave', this.doDestroy);
+ },
+ showMenu: function showMenu() {
+ var _this2 = this;
+
+ if (!this.menu) {
+ this.initMenu();
+ }
+
+ this.menu.value = this.currentValue.slice(0);
+ this.menu.visible = true;
+ this.menu.options = this.options;
+ this.$nextTick(function (_) {
+ _this2.updatePopper();
+ _this2.menu.inputWidth = _this2.$refs.input.$el.offsetWidth - 2;
+ });
+ },
+ hideMenu: function hideMenu() {
+ this.inputValue = '';
+ this.menu.visible = false;
+ },
+ handleActiveItemChange: function handleActiveItemChange(value) {
+ var _this3 = this;
+
+ this.$nextTick(function (_) {
+ _this3.updatePopper();
+ });
+ this.$emit('active-item-change', value);
+ },
+ handlePick: function handlePick(value) {
+ var close = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
+
+ this.currentValue = value;
+ this.$emit('input', value);
+ this.$emit('change', value);
+
+ if (close) {
+ this.menuVisible = false;
+ } else {
+ this.$nextTick(this.updatePopper);
+ }
+ },
+ handleInputChange: function handleInputChange(value) {
+ var _this4 = this;
+
+ if (!this.menuVisible) return;
+ var flatOptions = this.flatOptions;
+
+ if (!value) {
+ this.menu.options = this.options;
+ this.$nextTick(this.updatePopper);
+ return;
+ }
+
+ var filteredFlatOptions = flatOptions.filter(function (optionsStack) {
+ return optionsStack.some(function (option) {
+ return new RegExp(value, 'i').test(option[_this4.labelKey]);
+ });
+ });
+
+ if (filteredFlatOptions.length > 0) {
+ filteredFlatOptions = filteredFlatOptions.map(function (optionStack) {
+ return {
+ __IS__FLAT__OPTIONS: true,
+ value: optionStack.map(function (item) {
+ return item[_this4.valueKey];
+ }),
+ label: _this4.renderFilteredOptionLabel(value, optionStack)
+ };
+ });
+ } else {
+ filteredFlatOptions = [{
+ __IS__FLAT__OPTIONS: true,
+ label: this.t('el.cascader.noMatch'),
+ value: '',
+ disabled: true
+ }];
+ }
+ this.menu.options = filteredFlatOptions;
+ this.$nextTick(this.updatePopper);
+ },
+ renderFilteredOptionLabel: function renderFilteredOptionLabel(inputValue, optionsStack) {
+ var _this5 = this;
+
+ return optionsStack.map(function (option, index) {
+ var label = option[_this5.labelKey];
+ var keywordIndex = label.toLowerCase().indexOf(inputValue.toLowerCase());
+ var labelPart = label.slice(keywordIndex, inputValue.length + keywordIndex);
+ var node = keywordIndex > -1 ? _this5.highlightKeyword(label, labelPart) : label;
+ return index === 0 ? node : [' / ', node];
+ });
+ },
+ highlightKeyword: function highlightKeyword(label, keyword) {
+ var _this6 = this;
+
+ var h = this._c;
+ return label.split(keyword).map(function (node, index) {
+ return index === 0 ? node : [h('span', { class: { 'el-cascader-menu__item__keyword': true } }, [_this6._v(keyword)]), node];
+ });
+ },
+ flattenOptions: function flattenOptions(options) {
+ var _this7 = this;
+
+ var ancestor = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
+
+ var flatOptions = [];
+ options.forEach(function (option) {
+ var optionsStack = ancestor.concat(option);
+ if (!option[_this7.childrenKey]) {
+ flatOptions.push(optionsStack);
+ } else {
+ if (_this7.changeOnSelect) {
+ flatOptions.push(optionsStack);
+ }
+ flatOptions = flatOptions.concat(_this7.flattenOptions(option[_this7.childrenKey], optionsStack));
+ }
+ });
+ return flatOptions;
+ },
+ clearValue: function clearValue(ev) {
+ ev.stopPropagation();
+ this.handlePick([], true);
+ },
+ handleClickoutside: function handleClickoutside() {
+ this.menuVisible = false;
+ },
+ handleClick: function handleClick() {
+ if (this.disabled) return;
+ if (this.filterable) {
+ this.menuVisible = true;
+ this.$refs.input.$refs.input.focus();
+ return;
+ }
+ this.menuVisible = !this.menuVisible;
+ }
+ },
+
+ created: function created() {
+ var _this8 = this;
+
+ this.debouncedInputChange = (0, _debounce2.default)(this.debounce, function (value) {
+ var before = _this8.beforeFilter(value);
+
+ if (before && before.then) {
+ _this8.menu.options = [{
+ __IS__FLAT__OPTIONS: true,
+ label: _this8.t('el.cascader.loading'),
+ value: '',
+ disabled: true
+ }];
+ before.then(function () {
+ _this8.$nextTick(function () {
+ _this8.handleInputChange(value);
+ });
+ });
+ } else if (before !== false) {
+ _this8.$nextTick(function () {
+ _this8.handleInputChange(value);
+ });
+ }
+ });
+ },
+ mounted: function mounted() {
+ this.flatOptions = this.flattenOptions(this.options);
}
};
/***/ },
-/* 377 */
+/* 351 */
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(378),
+ __webpack_require__(352),
/* template */
- __webpack_require__(379),
+ null,
/* styles */
null,
/* scopeId */
@@ -61402,656 +60838,907 @@ module.exports =
/***/ },
-/* 378 */
+/* 352 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _checkboxGroup = __webpack_require__(143);
-
- var _checkboxGroup2 = _interopRequireDefault(_checkboxGroup);
-
- var _checkbox = __webpack_require__(130);
-
- var _checkbox2 = _interopRequireDefault(_checkbox);
+ var _babelHelperVueJsxMergeProps = __webpack_require__(353);
- var _input = __webpack_require__(20);
+ var _babelHelperVueJsxMergeProps2 = _interopRequireDefault(_babelHelperVueJsxMergeProps);
- var _input2 = _interopRequireDefault(_input);
+ var _shared = __webpack_require__(354);
- var _locale = __webpack_require__(10);
+ var _scrollIntoView = __webpack_require__(112);
- var _locale2 = _interopRequireDefault(_locale);
+ var _scrollIntoView2 = _interopRequireDefault(_scrollIntoView);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
-
- exports.default = {
- mixins: [_locale2.default],
-
- name: 'ElTransferPanel',
-
- componentName: 'ElTransferPanel',
-
- components: {
- ElCheckboxGroup: _checkboxGroup2.default,
- ElCheckbox: _checkbox2.default,
- ElInput: _input2.default,
- 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 parent = getParent(this);
- return parent.renderContent ? parent.renderContent(h, this.option) : h(
- 'span',
- null,
- [this.option[parent.labelProp] || this.option[parent.keyProp]]
- );
- }
+ var copyArray = function copyArray(arr, props) {
+ if (!arr || !Array.isArray(arr) || !props) return arr;
+ var result = [];
+ var configurableProps = ['__IS__FLAT__OPTIONS', 'label', 'value', 'disabled'];
+ var childrenProp = props.children || 'children';
+ arr.forEach(function (item) {
+ var itemCopy = {};
+ configurableProps.forEach(function (prop) {
+ var propName = props[prop] || prop;
+ var value = item[propName];
+ if (value !== undefined) itemCopy[propName] = value;
+ });
+ if (Array.isArray(item[childrenProp])) {
+ itemCopy[childrenProp] = copyArray(item[childrenProp], props);
}
- },
+ result.push(itemCopy);
+ });
+ return result;
+ };
- props: {
- data: {
- type: Array,
- default: function _default() {
- return [];
- }
- },
- renderContent: Function,
- placeholder: String,
- title: String,
- filterable: Boolean,
- footerFormat: Object,
- filterMethod: Function,
- defaultChecked: Array,
- props: Object
- },
+ exports.default = {
+ name: 'ElCascaderMenu',
data: function data() {
return {
- checked: [],
- allChecked: false,
- query: '',
- inputHover: false
+ inputWidth: 0,
+ options: [],
+ props: {},
+ visible: false,
+ activeValue: [],
+ value: [],
+ expandTrigger: 'click',
+ changeOnSelect: false,
+ popperClass: ''
};
},
watch: {
- checked: function checked(val) {
- this.updateAllChecked();
- this.$emit('checked-change', val);
- },
- 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.checked = checked;
- },
- checkableData: function checkableData() {
- this.updateAllChecked();
+ visible: function visible(value) {
+ if (value) {
+ this.activeValue = this.value;
+ }
},
-
- defaultChecked: {
+ value: {
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.checked = checked;
+ handler: function handler(value) {
+ this.activeValue = value;
}
}
},
computed: {
- filteredData: function filteredData() {
- var _this3 = this;
+ activeOptions: {
+ cache: false,
+ get: function get() {
+ var _this = 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;
+ var activeValue = this.activeValue;
+ var configurableProps = ['label', 'value', 'children', 'disabled'];
- return this.filteredData.filter(function (item) {
- return !item[_this4.disabledProp];
- });
- },
- checkedSummary: function checkedSummary() {
- var checkedLength = this.checked.length;
- var dataLength = this.data.length;
- var _footerFormat = this.footerFormat,
- noChecked = _footerFormat.noChecked,
- hasChecked = _footerFormat.hasChecked;
+ var formatOptions = function formatOptions(options) {
+ options.forEach(function (option) {
+ if (option.__IS__FLAT__OPTIONS) return;
+ configurableProps.forEach(function (prop) {
+ var value = option[_this.props[prop] || prop];
+ if (value !== undefined) option[prop] = value;
+ });
+ if (Array.isArray(option.children)) {
+ formatOptions(option.children);
+ }
+ });
+ };
- if (noChecked && hasChecked) {
- return checkedLength > 0 ? hasChecked.replace(/\${checked}/g, checkedLength).replace(/\${total}/g, dataLength) : noChecked.replace(/\${total}/g, dataLength);
+ var loadActiveOptions = function loadActiveOptions(options) {
+ var activeOptions = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
+
+ var level = activeOptions.length;
+ activeOptions[level] = options;
+ var active = activeValue[level];
+ if ((0, _shared.isDef)(active)) {
+ options = options.filter(function (option) {
+ return option.value === active;
+ })[0];
+ if (options && options.children) {
+ loadActiveOptions(options.children, activeOptions);
+ }
+ }
+ return activeOptions;
+ };
+
+ var optionsCopy = copyArray(this.options, this.props);
+ formatOptions(optionsCopy);
+ return loadActiveOptions(optionsCopy);
+ }
+ }
+ },
+
+ methods: {
+ select: function select(item, menuIndex) {
+ if (item.__IS__FLAT__OPTIONS) {
+ this.activeValue = item.value;
+ } else if (menuIndex) {
+ this.activeValue.splice(menuIndex, this.activeValue.length - 1, item.value);
} else {
- return checkedLength > 0 ? this.t('el.transfer.hasCheckedFormat', { total: dataLength, checked: checkedLength }) : this.t('el.transfer.noCheckedFormat', { total: dataLength });
+ this.activeValue = [item.value];
}
+ this.$emit('pick', this.activeValue.slice());
},
- 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';
+ handleMenuLeave: function handleMenuLeave() {
+ this.$emit('menuLeave');
},
- labelProp: function labelProp() {
- return this.props.label || 'label';
+ activeItem: function activeItem(item, menuIndex) {
+ var len = this.activeOptions.length;
+ this.activeValue.splice(menuIndex, len, item.value);
+ this.activeOptions.splice(menuIndex + 1, len, item.children);
+ if (this.changeOnSelect) {
+ this.$emit('pick', this.activeValue.slice(), false);
+ } else {
+ this.$emit('activeItemChange', this.activeValue);
+ }
},
- keyProp: function keyProp() {
- return this.props.key || 'key';
+ scrollMenu: function scrollMenu(menu) {
+ (0, _scrollIntoView2.default)(menu, menu.getElementsByClassName('is-active')[0]);
},
- disabledProp: function disabledProp() {
- return this.props.disabled || 'disabled';
+ handleMenuEnter: function handleMenuEnter() {
+ var _this2 = this;
+
+ this.$nextTick(function () {
+ return _this2.$refs.menus.forEach(function (menu) {
+ return _this2.scrollMenu(menu);
+ });
+ });
}
},
- methods: {
- updateAllChecked: function updateAllChecked() {
- var _this5 = this;
+ render: function render(h) {
+ var _this3 = 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;
+ var activeValue = this.activeValue,
+ activeOptions = this.activeOptions,
+ visible = this.visible,
+ expandTrigger = this.expandTrigger,
+ popperClass = this.popperClass;
- this.checked = value.target.checked ? this.checkableData.map(function (item) {
- return item[_this6.keyProp];
- }) : [];
- },
- clearQuery: function clearQuery() {
- if (this.inputIcon === 'circle-close') {
- this.query = '';
+
+ var menus = this._l(activeOptions, function (menu, menuIndex) {
+ var isFlat = false;
+ var items = _this3._l(menu, function (item) {
+ var events = {
+ on: {}
+ };
+
+ if (item.__IS__FLAT__OPTIONS) isFlat = true;
+
+ if (!item.disabled) {
+ if (item.children) {
+ var triggerEvent = {
+ click: 'click',
+ hover: 'mouseenter'
+ }[expandTrigger];
+ events.on[triggerEvent] = function () {
+ _this3.activeItem(item, menuIndex);
+ _this3.$nextTick(function () {
+ // adjust self and next level
+ _this3.scrollMenu(_this3.$refs.menus[menuIndex]);
+ _this3.scrollMenu(_this3.$refs.menus[menuIndex + 1]);
+ });
+ };
+ } else {
+ events.on.click = function () {
+ _this3.select(item, menuIndex);
+ _this3.$nextTick(function () {
+ return _this3.scrollMenu(_this3.$refs.menus[menuIndex]);
+ });
+ };
+ }
+ }
+
+ return h(
+ 'li',
+ (0, _babelHelperVueJsxMergeProps2.default)([{
+ 'class': {
+ 'el-cascader-menu__item': true,
+ 'el-cascader-menu__item--extensible': item.children,
+ 'is-active': item.value === activeValue[menuIndex],
+ 'is-disabled': item.disabled
+ }
+ }, events]),
+ [item.label]
+ );
+ });
+ var menuStyle = {};
+ if (isFlat) {
+ menuStyle.minWidth = _this3.inputWidth + 'px';
}
- }
+
+ return h(
+ 'ul',
+ {
+ 'class': {
+ 'el-cascader-menu': true,
+ 'el-cascader-menu--flexible': isFlat
+ },
+ style: menuStyle,
+ refInFor: true,
+ ref: 'menus' },
+ [items]
+ );
+ });
+ return h(
+ 'transition',
+ {
+ attrs: { name: 'el-zoom-in-top' },
+ on: {
+ 'before-enter': this.handleMenuEnter,
+ 'after-leave': this.handleMenuLeave
+ }
+ },
+ [h(
+ 'div',
+ {
+ directives: [{
+ name: 'show',
+ value: visible
+ }],
+
+ 'class': ['el-cascader-menus', popperClass],
+ ref: 'wrapper'
+ },
+ [menus]
+ )]
+ );
}
};
/***/ },
-/* 379 */
+/* 353 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(80);
+
+/***/ },
+/* 354 */
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(81);
+
+/***/ },
+/* 355 */
/***/ function(module, exports) {
module.exports={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"
- }, [_vm._v(_vm._s(_vm.title))]), _c('div', {
- staticClass: "el-transfer-panel__body"
- }, [(_vm.filterable) ? _c('el-input', {
- staticClass: "el-transfer-panel__filter",
- attrs: {
- "size": "small",
- "placeholder": _vm.placeholder,
- "icon": _vm.inputIcon
- },
+ return _c('span', {
+ directives: [{
+ name: "clickoutside",
+ rawName: "v-clickoutside",
+ value: (_vm.handleClickoutside),
+ expression: "handleClickoutside"
+ }],
+ ref: "reference",
+ staticClass: "el-cascader",
+ class: [{
+ 'is-opened': _vm.menuVisible,
+ 'is-disabled': _vm.disabled
+ },
+ _vm.size ? 'el-cascader--' + _vm.size : ''
+ ],
on: {
- "click": _vm.clearQuery
- },
- nativeOn: {
+ "click": _vm.handleClick,
"mouseenter": function($event) {
_vm.inputHover = true
},
"mouseleave": function($event) {
_vm.inputHover = false
}
- },
- model: {
- value: (_vm.query),
- callback: function($$v) {
- _vm.query = $$v
- },
- expression: "query"
- }
- }) : _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)
- })), _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), _c('p', {
- staticClass: "el-transfer-panel__footer"
- }, [_c('el-checkbox', {
+ }, [_c('el-input', {
+ ref: "input",
attrs: {
- "indeterminate": _vm.isIndeterminate
+ "readonly": !_vm.filterable,
+ "placeholder": _vm.currentLabels.length ? undefined : _vm.placeholder,
+ "validate-event": false,
+ "size": _vm.size,
+ "disabled": _vm.disabled
},
on: {
- "change": _vm.handleAllCheckedChange
+ "change": _vm.debouncedInputChange
},
model: {
- value: (_vm.allChecked),
+ value: (_vm.inputValue),
callback: function($$v) {
- _vm.allChecked = $$v
+ _vm.inputValue = $$v
},
- expression: "allChecked"
+ expression: "inputValue"
}
- }, [_vm._v(_vm._s(_vm.checkedSummary))]), _vm._t("default")], 2)])
- },staticRenderFns: []}
-
-/***/ },
-/* 380 */
-/***/ function(module, exports) {
-
- module.exports={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({
- 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')
- },
+ }, [_c('template', {
+ slot: "icon"
+ }, [(_vm.clearable && _vm.inputHover && _vm.currentLabels.length) ? _c('i', {
+ key: "1",
+ staticClass: "el-input__icon el-icon-circle-close el-cascader__clearIcon",
on: {
- "checked-change": _vm.onSourceCheckedChange
- }
- }, 'transfer-panel', _vm.$props), [_vm._t("left-footer")], 2), _c('div', {
- staticClass: "el-transfer__buttons"
- }, [_c('el-button', {
- attrs: {
- "type": "primary",
- "size": "small",
- "disabled": _vm.rightChecked.length === 0
- },
- nativeOn: {
- "click": function($event) {
- _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', {
- attrs: {
- "type": "primary",
- "size": "small",
- "disabled": _vm.leftChecked.length === 0
- },
- nativeOn: {
- "click": function($event) {
- _vm.addToRight($event)
- }
+ "click": _vm.clearValue
}
- }, [(_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({
- 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
+ }) : _c('i', {
+ key: "2",
+ staticClass: "el-input__icon el-icon-caret-bottom",
+ class: {
+ 'is-reverse': _vm.menuVisible
}
- }, 'transfer-panel', _vm.$props), [_vm._t("right-footer")], 2)], 1)
+ })])], 2), _c('span', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.inputValue === ''),
+ expression: "inputValue === ''"
+ }],
+ staticClass: "el-cascader__label"
+ }, [(_vm.showAllLevels) ? [_vm._l((_vm.currentLabels), function(label, index) {
+ return [_vm._v("\n " + _vm._s(label) + "\n "), (index < _vm.currentLabels.length - 1) ? _c('span', [_vm._v(" / ")]) : _vm._e()]
+ })] : [_vm._v("\n " + _vm._s(_vm.currentLabels[_vm.currentLabels.length - 1]) + "\n ")]], 2)], 1)
},staticRenderFns: []}
-/***/ }
-/******/ ]);
+/***/ },
+/* 356 */
+/***/ function(module, exports, __webpack_require__) {
-/***/ }),
-/* 41 */
-/***/ (function(module, exports, __webpack_require__) {
+ 'use strict';
-module.exports =
-/******/ (function(modules) { // webpackBootstrap
-/******/ // The module cache
-/******/ var installedModules = {};
+ exports.__esModule = true;
-/******/ // The require function
-/******/ function __webpack_require__(moduleId) {
+ var _main = __webpack_require__(357);
-/******/ // Check if module is in cache
-/******/ if(installedModules[moduleId])
-/******/ return installedModules[moduleId].exports;
+ var _main2 = _interopRequireDefault(_main);
-/******/ // Create a new module (and put it into the cache)
-/******/ var module = installedModules[moduleId] = {
-/******/ exports: {},
-/******/ id: moduleId,
-/******/ loaded: false
-/******/ };
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-/******/ // Execute the module function
-/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
+ /* istanbul ignore next */
+ _main2.default.install = function (Vue) {
+ Vue.component(_main2.default.name, _main2.default);
+ };
-/******/ // Flag the module as loaded
-/******/ module.loaded = true;
+ exports.default = _main2.default;
-/******/ // Return the exports of the module
-/******/ return module.exports;
-/******/ }
+/***/ },
+/* 357 */
+/***/ function(module, exports, __webpack_require__) {
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(358),
+ /* template */
+ __webpack_require__(373),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
-/******/ // expose the modules object (__webpack_modules__)
-/******/ __webpack_require__.m = modules;
+ module.exports = Component.exports
-/******/ // expose the module cache
-/******/ __webpack_require__.c = installedModules;
-/******/ // __webpack_public_path__
-/******/ __webpack_require__.p = "/dist/";
+/***/ },
+/* 358 */
+/***/ function(module, exports, __webpack_require__) {
-/******/ // Load entry module and return exports
-/******/ return __webpack_require__(0);
-/******/ })
-/************************************************************************/
-/******/ ({
+ 'use strict';
-/***/ 0:
-/***/ function(module, exports, __webpack_require__) {
+ exports.__esModule = true;
- module.exports = __webpack_require__(264);
+ var _color = __webpack_require__(359);
+ var _color2 = _interopRequireDefault(_color);
-/***/ },
+ var _pickerDropdown = __webpack_require__(360);
-/***/ 3:
-/***/ function(module, exports) {
+ var _pickerDropdown2 = _interopRequireDefault(_pickerDropdown);
- /* globals __VUE_SSR_CONTEXT__ */
+ var _clickoutside = __webpack_require__(21);
- // this module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle
+ var _clickoutside2 = _interopRequireDefault(_clickoutside);
- module.exports = function normalizeComponent (
- rawScriptExports,
- compiledTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier /* server only */
- ) {
- var esModule
- var scriptExports = rawScriptExports = rawScriptExports || {}
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- // ES6 modules interop
- var type = typeof rawScriptExports.default
- if (type === 'object' || type === 'function') {
- esModule = rawScriptExports
- scriptExports = rawScriptExports.default
- }
+ exports.default = {
+ name: 'ElColorPicker',
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
+ props: {
+ value: {
+ type: String
+ },
+ showAlpha: {
+ type: Boolean
+ },
+ colorFormat: {
+ type: String
+ }
+ },
- // render functions
- if (compiledTemplate) {
- options.render = compiledTemplate.render
- options.staticRenderFns = compiledTemplate.staticRenderFns
- }
+ directives: { Clickoutside: _clickoutside2.default },
- // scopedId
- if (scopeId) {
- options._scopeId = scopeId
- }
+ computed: {
+ displayedColor: function displayedColor() {
+ if (!this.value && !this.showPanelColor) {
+ return 'transparent';
+ } else {
+ var _color$toRgb = this.color.toRgb(),
+ r = _color$toRgb.r,
+ g = _color$toRgb.g,
+ b = _color$toRgb.b;
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context = context || (this.$vnode && this.$vnode.ssrContext)
- // 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)
+ return this.showAlpha ? 'rgba(' + r + ', ' + g + ', ' + b + ', ' + this.color.get('alpha') / 100 + ')' : 'rgb(' + r + ', ' + g + ', ' + b + ')';
}
}
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = injectStyles
- }
-
- if (hook) {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
+ },
- return {
- esModule: esModule,
- exports: scriptExports,
- options: options
- }
- }
+ 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) {
+ this.$emit('active-change', val);
+ }
+ },
-/***/ },
+ methods: {
+ confirmValue: function confirmValue(value) {
+ this.$emit('input', this.color.value);
+ this.$emit('change', this.color.value);
+ this.showPicker = false;
+ },
+ clearValue: function clearValue() {
+ this.$emit('input', null);
+ this.$emit('change', null);
+ this.showPanelColor = false;
+ this.showPicker = false;
+ this.resetColor();
+ },
+ hide: function hide() {
+ this.showPicker = false;
+ this.resetColor();
+ },
+ resetColor: function resetColor() {
+ var _this = this;
-/***/ 9:
-/***/ function(module, exports) {
+ this.$nextTick(function (_) {
+ if (_this.value) {
+ _this.color.fromString(_this.value);
+ } else {
+ _this.showPanelColor = false;
+ }
+ });
+ }
+ },
- module.exports = __webpack_require__(11);
+ 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 _color2.default({
+ enableAlpha: this.showAlpha,
+ format: this.colorFormat
+ });
+ return {
+ color: color,
+ showPicker: false,
+ showPanelColor: false
+ };
+ },
-/***/ },
-/***/ 10:
+ components: {
+ PickerDropdown: _pickerDropdown2.default
+ }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+/***/ },
+/* 359 */
/***/ function(module, exports) {
- module.exports = __webpack_require__(20);
+ 'use strict';
-/***/ },
+ exports.__esModule = true;
-/***/ 13:
-/***/ function(module, exports) {
+ 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; };
- module.exports = __webpack_require__(13);
+ function _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];
+ };
-/***/ 14:
-/***/ function(module, exports) {
+ // Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1
+ //
+ var isOnePointZero = function isOnePointZero(n) {
+ return typeof n === 'string' && n.indexOf('.') !== -1 && parseFloat(n) === 1;
+ };
- module.exports = __webpack_require__(5);
+ 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%';
-/***/ 15:
-/***/ function(module, exports) {
+ var processPercent = isPercentage(value);
+ value = Math.min(max, Math.max(0, parseFloat(value)));
- module.exports = __webpack_require__(22);
+ // 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;
+ }
-/***/ 46:
-/***/ function(module, exports) {
+ // Convert into [0, 1] range if it isn't already
+ return value % max / parseFloat(max);
+ };
- module.exports = __webpack_require__(15);
+ 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;
-/***/ 60:
-/***/ function(module, exports) {
+ 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);
+ };
- module.exports = __webpack_require__(23);
+ if (isNaN(r) || isNaN(g) || isNaN(b)) return '';
-/***/ },
+ return '#' + hexOne(r) + hexOne(g) + hexOne(b);
+ };
-/***/ 61:
-/***/ function(module, exports) {
+ var HEX_INT_MAP = { A: 10, B: 11, C: 12, D: 13, E: 14, F: 15 };
- module.exports = __webpack_require__(24);
+ 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];
+ };
-/***/ 62:
-/***/ function(module, exports) {
+ 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;
- module.exports = __webpack_require__(16);
+ 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
+ };
+ };
-/***/ 63:
-/***/ function(module, exports) {
+ // `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);
- module.exports = __webpack_require__(9);
+ 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;
-/***/ 123:
-/***/ function(module, exports) {
+ 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;
+ }
- module.exports = __webpack_require__(4);
+ 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);
-/***/ 217:
+ 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) {
+ _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' : _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 = h;
+ _this._saturation = s;
+ _this._value = 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);
+ }
+ 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);
+ }
+ 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);
+ }
+ 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();
+ 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) {
+ r = parseHexChannel(hex.substring(0, 2));
+ g = parseHexChannel(hex.substring(2, 4));
+ b = parseHexChannel(hex.substring(4));
+ }
+
+ var _rgb2hsv2 = rgb2hsv(r, g, b),
+ _h2 = _rgb2hsv2.h,
+ _s2 = _rgb2hsv2.s,
+ _v2 = _rgb2hsv2.v;
+
+ fromHSV(_h2, _s2, _v2);
+ }
+ };
+
+ 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;
+ }();
+
+ exports.default = Color;
+ ;
+
+/***/ },
+/* 360 */
/***/ function(module, exports, __webpack_require__) {
- var Component = __webpack_require__(3)(
+ var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(218),
+ __webpack_require__(361),
/* template */
- __webpack_require__(220),
+ __webpack_require__(372),
/* styles */
null,
/* scopeId */
@@ -62064,351 +61751,228 @@ module.exports =
/***/ },
-
-/***/ 218:
+/* 361 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- 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; }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ var _svPanel = __webpack_require__(362);
- var _emitter = __webpack_require__(14);
+ var _svPanel2 = _interopRequireDefault(_svPanel);
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _hueSlider = __webpack_require__(366);
- var _util = __webpack_require__(219);
+ var _hueSlider2 = _interopRequireDefault(_hueSlider);
+
+ var _alphaSlider = __webpack_require__(369);
+
+ var _alphaSlider2 = _interopRequireDefault(_alphaSlider);
+
+ var _vuePopper = __webpack_require__(24);
+
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
+
+ var _locale = __webpack_require__(10);
+
+ var _locale2 = _interopRequireDefault(_locale);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- mixins: [_emitter2.default],
+ name: 'el-color-picker-dropdown',
- name: 'ElOption',
+ mixins: [_vuePopper2.default, _locale2.default],
- componentName: 'ElOption',
+ components: {
+ SvPanel: _svPanel2.default,
+ HueSlider: _hueSlider2.default,
+ AlphaSlider: _alphaSlider2.default
+ },
props: {
- value: {
+ color: {
required: true
},
- label: [String, Number],
- created: Boolean,
- disabled: {
- type: Boolean,
- default: false
+ showAlpha: Boolean
+ },
+
+ computed: {
+ currentColor: function currentColor() {
+ var parent = this.$parent;
+ return !parent.value && !parent.showPanelColor ? '' : parent.color.value;
}
},
- data: function data() {
- return {
- index: -1,
- groupDisabled: false,
- visible: true,
- hitState: false
- };
+ methods: {
+ confirmValue: function confirmValue() {
+ this.$emit('pick');
+ }
},
+ mounted: function mounted() {
+ this.$parent.popperElm = this.popperElm = this.$el;
+ this.referenceElm = this.$parent.$el;
+ },
- 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 || '';
- },
- parent: function parent() {
- var result = this.$parent;
- while (!result.isSelect) {
- result = result.$parent;
- }
- return result;
- },
- itemSelected: function itemSelected() {
- if (!this.parent.multiple) {
- return this.isEqual(this.value, this.parent.value);
- } else {
- return this.contains(this.parent.value, this.value);
- }
- },
- limitReached: function limitReached() {
- if (this.parent.multiple) {
- return !this.itemSelected && this.parent.value.length >= this.parent.multipleLimit && this.parent.multipleLimit > 0;
- } else {
- return false;
- }
- }
- },
watch: {
- currentLabel: function currentLabel() {
- if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
- },
- value: function value() {
- if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
- }
- },
-
- methods: {
- isEqual: function isEqual(a, b) {
- if (!this.isObject) {
- return a === b;
- } else {
- var valueKey = this.parent.valueKey;
- return (0, _util.getValueByPath)(a, valueKey) === (0, _util.getValueByPath)(b, valueKey);
- }
- },
- contains: function contains() {
+ showPopper: function showPopper(val) {
var _this = this;
- var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var target = arguments[1];
-
- if (!this.isObject) {
- return arr.indexOf(target) > -1;
- } else {
- var _ret = function () {
- var valueKey = _this.parent.valueKey;
- return {
- v: arr.some(function (item) {
- return (0, _util.getValueByPath)(item, valueKey) === (0, _util.getValueByPath)(target, valueKey);
- })
- };
- }();
+ if (val === true) {
+ this.$nextTick(function () {
+ var _$refs = _this.$refs,
+ sl = _$refs.sl,
+ hue = _$refs.hue,
+ alpha = _$refs.alpha;
- if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
- }
- },
- handleGroupDisabled: function handleGroupDisabled(val) {
- this.groupDisabled = val;
- },
- hoverItem: function hoverItem() {
- if (!this.disabled && !this.groupDisabled) {
- this.parent.hoverIndex = this.parent.options.indexOf(this);
- }
- },
- selectOptionClick: function selectOptionClick() {
- if (this.disabled !== true && this.groupDisabled !== true) {
- this.dispatch('ElSelect', 'handleOptionClick', this);
- }
- },
- queryChange: function queryChange(query) {
- // query 里如果有正则中的特殊字符,需要先将这些字符转义
- var parsedQuery = String(query).replace(/(\^|\(|\)|\[|\]|\$|\*|\+|\.|\?|\\|\{|\}|\|)/g, '\\$1');
- this.visible = new RegExp(parsedQuery, 'i').test(this.currentLabel) || this.created;
- if (!this.visible) {
- this.parent.filteredOptionsCount--;
+ sl && sl.update();
+ hue && hue.update();
+ alpha && alpha.update();
+ });
}
- },
- resetIndex: function resetIndex() {
- var _this2 = this;
-
- this.$nextTick(function () {
- _this2.index = _this2.parent.options.indexOf(_this2);
- });
}
- },
-
- created: function created() {
- this.parent.options.push(this);
- this.parent.cachedOptions.push(this);
- this.parent.optionsCount++;
- this.parent.filteredOptionsCount++;
- this.index = this.parent.options.indexOf(this);
-
- this.$on('queryChange', this.queryChange);
- this.$on('handleGroupDisabled', this.handleGroupDisabled);
- this.$on('resetIndex', this.resetIndex);
- },
- beforeDestroy: function beforeDestroy() {
- this.dispatch('ElSelect', 'onOptionDestroy', this);
}
- };
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
/***/ },
+/* 362 */
+/***/ function(module, exports, __webpack_require__) {
-/***/ 219:
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(6);
-
-/***/ },
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(363),
+ /* template */
+ __webpack_require__(365),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
-/***/ 220:
-/***/ function(module, exports) {
+ module.exports = Component.exports
- module.exports={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.parent.hoverIndex === _vm.index
- },
- on: {
- "mouseenter": _vm.hoverItem,
- "click": function($event) {
- $event.stopPropagation();
- _vm.selectOptionClick($event)
- }
- }
- }, [_vm._t("default", [_c('span', [_vm._v(_vm._s(_vm.currentLabel))])])], 2)
- },staticRenderFns: []}
/***/ },
-
-/***/ 264:
+/* 363 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _select = __webpack_require__(265);
+ var _draggable = __webpack_require__(364);
- var _select2 = _interopRequireDefault(_select);
+ var _draggable2 = _interopRequireDefault(_draggable);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- /* istanbul ignore next */
- _select2.default.install = function (Vue) {
- Vue.component(_select2.default.name, _select2.default);
- };
+ exports.default = {
+ name: 'el-sl-panel',
- exports.default = _select2.default;
+ 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 };
+ }
+ },
-/***/ 265:
-/***/ function(module, exports, __webpack_require__) {
+ watch: {
+ colorValue: function colorValue() {
+ this.update();
+ }
+ },
- var Component = __webpack_require__(3)(
- /* script */
- __webpack_require__(266),
- /* template */
- __webpack_require__(271),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ methods: {
+ update: function update() {
+ var saturation = this.color.get('saturation');
+ var value = this.color.get('value');
- module.exports = Component.exports
+ var el = this.$el;
+ var _el$getBoundingClient = el.getBoundingClientRect(),
+ width = _el$getBoundingClient.width,
+ height = _el$getBoundingClient.height;
-/***/ },
+ if (!height) height = width * 3 / 4;
-/***/ 266:
-/***/ function(module, exports, __webpack_require__) {
+ this.cursorLeft = saturation * width / 100;
+ this.cursorTop = (100 - value) * height / 100;
- 'use strict';
+ this.background = 'hsl(' + this.color.get('hue') + ', 100%, 50%)';
+ },
+ handleDrag: function handleDrag(event) {
+ var el = this.$el;
+ var rect = el.getBoundingClientRect();
- exports.__esModule = true;
+ var left = event.clientX - rect.left;
+ var top = event.clientY - rect.top;
+ left = Math.max(0, left);
+ left = Math.min(left, rect.width);
- 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; }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ 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;
+
+ (0, _draggable2.default)(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%)'
+ };
+ }
+ }; //
//
//
//
@@ -62426,666 +61990,607 @@ module.exports =
//
//
- var _emitter = __webpack_require__(14);
-
- var _emitter2 = _interopRequireDefault(_emitter);
+/***/ },
+/* 364 */
+/***/ function(module, exports, __webpack_require__) {
- var _locale = __webpack_require__(61);
+ 'use strict';
- var _locale2 = _interopRequireDefault(_locale);
+ exports.__esModule = true;
- var _input = __webpack_require__(9);
+ exports.default = function (element, options) {
+ if (_vue2.default.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;
- var _input2 = _interopRequireDefault(_input);
+ isDragging = false;
- var _selectDropdown = __webpack_require__(267);
+ if (options.end) {
+ options.end(event);
+ }
+ };
+ element.addEventListener('mousedown', function (event) {
+ if (isDragging) return;
+ document.onselectstart = function () {
+ return false;
+ };
+ document.ondragstart = function () {
+ return false;
+ };
- var _selectDropdown2 = _interopRequireDefault(_selectDropdown);
+ document.addEventListener('mousemove', moveFn);
+ document.addEventListener('mouseup', upFn);
+ isDragging = true;
- var _option = __webpack_require__(217);
+ if (options.start) {
+ options.start(event);
+ }
+ });
+ };
- var _option2 = _interopRequireDefault(_option);
+ var _vue = __webpack_require__(133);
- var _tag = __webpack_require__(270);
+ var _vue2 = _interopRequireDefault(_vue);
- var _tag2 = _interopRequireDefault(_tag);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var _scrollbar = __webpack_require__(15);
+ var isDragging = false;
- var _scrollbar2 = _interopRequireDefault(_scrollbar);
+/***/ },
+/* 365 */
+/***/ function(module, exports) {
- var _debounce = __webpack_require__(63);
+ module.exports={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')])])
+ },staticRenderFns: []}
- var _debounce2 = _interopRequireDefault(_debounce);
+/***/ },
+/* 366 */
+/***/ function(module, exports, __webpack_require__) {
- var _clickoutside = __webpack_require__(10);
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(367),
+ /* template */
+ __webpack_require__(368),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- var _clickoutside2 = _interopRequireDefault(_clickoutside);
+ module.exports = Component.exports
- var _dom = __webpack_require__(123);
- var _resizeEvent = __webpack_require__(46);
+/***/ },
+/* 367 */
+/***/ function(module, exports, __webpack_require__) {
- var _locale3 = __webpack_require__(62);
+ 'use strict';
- var _scrollIntoView = __webpack_require__(60);
+ exports.__esModule = true;
- var _scrollIntoView2 = _interopRequireDefault(_scrollIntoView);
+ var _draggable = __webpack_require__(364);
- var _util = __webpack_require__(219);
+ var _draggable2 = _interopRequireDefault(_draggable);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var sizeMap = {
- 'large': 42,
- 'small': 30,
- 'mini': 22
- };
-
exports.default = {
- mixins: [_emitter2.default, _locale2.default],
-
- name: 'ElSelect',
-
- componentName: 'ElSelect',
+ name: 'el-color-hue-slider',
- computed: {
- iconClass: function iconClass() {
- var criteria = this.clearable && !this.disabled && this.inputHovering && !this.multiple && this.value !== undefined && this.value !== '';
- return criteria ? 'circle-close is-show-close' : this.remote && this.filterable ? '' : 'caret-top';
- },
- 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.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;
+ props: {
+ color: {
+ required: true
},
- 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;
- }
+ vertical: Boolean
},
- components: {
- ElInput: _input2.default,
- ElSelectMenu: _selectDropdown2.default,
- ElOption: _option2.default,
- ElTag: _tag2.default,
- ElScrollbar: _scrollbar2.default
+ data: function data() {
+ return {
+ thumbLeft: 0,
+ thumbTop: 0
+ };
},
- directives: { Clickoutside: _clickoutside2.default },
- props: {
- name: String,
- value: {
- required: true
- },
- 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 (0, _locale3.t)('el.select.placeholder');
- }
- },
- defaultFirstOption: Boolean,
- valueKey: {
- type: String,
- default: 'value'
+ computed: {
+ hueValue: function hueValue() {
+ var hue = this.color.get('hue');
+ return hue;
}
},
- data: function data() {
- return {
- options: [],
- cachedOptions: [],
- createdLabel: null,
- createdSelected: false,
- selected: this.multiple ? [] : {},
- isSelect: true,
- inputLength: 20,
- inputWidth: 0,
- cachedPlaceHolder: '',
- optionsCount: 0,
- filteredOptionsCount: 0,
- visible: false,
- selectedLabel: '',
- hoverIndex: -1,
- query: '',
- optionsAllDisabled: false,
- inputHovering: false,
- currentPlaceholder: ''
- };
+ watch: {
+ hueValue: function hueValue() {
+ this.update();
+ }
},
+ methods: {
+ handleClick: function handleClick(event) {
+ var thumb = this.$refs.thumb;
+ var target = event.target;
- watch: {
- placeholder: function placeholder(val) {
- this.cachedPlaceHolder = this.currentPlaceholder = val;
- },
- value: function value(val) {
- if (this.multiple) {
- this.resetInputHeight();
- if (val.length > 0 || this.$refs.input && this.query !== '') {
- this.currentPlaceholder = '';
- } else {
- this.currentPlaceholder = this.cachedPlaceHolder;
- }
- }
- this.setSelected();
- if (this.filterable && !this.multiple) {
- this.inputLength = 20;
+ if (target !== thumb) {
+ this.handleDrag(event);
}
- this.$emit('change', val);
- this.dispatch('ElFormItem', 'el.form.change', val);
},
- query: function query(val) {
- var _this2 = this;
+ handleDrag: function handleDrag(event) {
+ var rect = this.$el.getBoundingClientRect();
+ var thumb = this.$refs.thumb;
- this.$nextTick(function () {
- if (_this2.visible) _this2.broadcast('ElSelectDropdown', 'updatePopper');
- });
- this.hoverIndex = -1;
- if (this.multiple && this.filterable) {
- this.inputLength = this.$refs.input.value.length * 15 + 20;
- this.managePlaceholder();
- this.resetInputHeight();
- }
- if (this.remote && typeof this.remoteMethod === 'function') {
- this.hoverIndex = -1;
- this.remoteMethod(val);
- this.broadcast('ElOption', 'resetIndex');
- } else if (typeof this.filterMethod === 'function') {
- this.filterMethod(val);
- this.broadcast('ElOptionGroup', 'queryChange');
+ 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 {
- this.filteredOptionsCount = this.optionsCount;
- this.broadcast('ElOption', 'queryChange', val);
- this.broadcast('ElOptionGroup', 'queryChange');
- }
- if (this.defaultFirstOption && (this.filterable || this.remote) && this.filteredOptionsCount) {
- this.checkDefaultFirstOption();
+ 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);
},
- visible: function visible(val) {
- var _this3 = this;
+ getThumbLeft: function getThumbLeft() {
+ if (this.vertical) return 0;
+ var el = this.$el;
+ var hue = this.color.get('hue');
- if (!val) {
- this.$refs.reference.$el.querySelector('input').blur();
- this.handleIconHide();
- this.broadcast('ElSelectDropdown', 'destroyPopper');
- if (this.$refs.input) {
- this.$refs.input.blur();
- }
- this.query = '';
- this.selectedLabel = '';
- this.inputLength = 20;
- 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.createdOption) {
- this.selectedLabel = this.createdLabel;
- } else {
- this.selectedLabel = this.selected.currentLabel;
- }
- if (this.filterable) this.query = this.selectedLabel;
- }
- }
- } else {
- this.handleIconShow();
- this.broadcast('ElSelectDropdown', 'updatePopper');
- if (this.filterable) {
- this.query = this.selectedLabel;
- if (this.multiple) {
- this.$refs.input.focus();
- } else {
- if (!this.remote) {
- this.broadcast('ElOption', 'queryChange', '');
- this.broadcast('ElOptionGroup', 'queryChange');
- }
- this.broadcast('ElInput', 'inputSelect');
- }
- }
- }
- this.$emit('visible-change', val);
+ if (!el) return 0;
+ var thumb = this.$refs.thumb;
+ return Math.round(hue * (el.offsetWidth - thumb.offsetWidth / 2) / 360);
},
- options: function options(val) {
- if (this.$isServer) return;
- this.optionsAllDisabled = val.length === val.filter(function (item) {
- return item.disabled === true;
- }).length;
- 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();
- }
+ 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();
}
},
- methods: {
- handleIconHide: function handleIconHide() {
- var icon = this.$el.querySelector('.el-input__icon');
- if (icon) {
- (0, _dom.removeClass)(icon, 'is-reverse');
- }
- },
- handleIconShow: function handleIconShow() {
- var icon = this.$el.querySelector('.el-input__icon');
- if (icon && !(0, _dom.hasClass)(icon, 'el-icon-circle-close')) {
- (0, _dom.addClass)(icon, 'is-reverse');
- }
- },
- 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');
- (0, _scrollIntoView2.default)(menu, target);
- }
- },
- handleMenuEnter: function handleMenuEnter() {
- var _this4 = this;
+ mounted: function mounted() {
+ var _this = this;
- this.$nextTick(function () {
- return _this4.scrollToOption(_this4.selected);
- });
- },
- getOption: function getOption(value) {
- var option = void 0;
- var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
- for (var i = this.cachedOptions.length - 1; i >= 0; i--) {
- var cachedOption = this.cachedOptions[i];
- var isEqual = isObject ? (0, _util.getValueByPath)(cachedOption.value, this.valueKey) === (0, _util.getValueByPath)(value, this.valueKey) : cachedOption.value === value;
- if (isEqual) {
- option = cachedOption;
- break;
- }
- }
- if (option) return option;
- var label = !isObject ? value : '';
- var newOption = {
- value: value,
- currentLabel: label
- };
- if (this.multiple) {
- newOption.hitState = false;
- }
- return newOption;
- },
- setSelected: function setSelected() {
- var _this5 = this;
+ var _$refs = this.$refs,
+ bar = _$refs.bar,
+ thumb = _$refs.thumb;
- 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(_this5.getOption(value));
- });
+
+ var dragConfig = {
+ drag: function drag(event) {
+ _this.handleDrag(event);
+ },
+ end: function end(event) {
+ _this.handleDrag(event);
}
- this.selected = result;
- this.$nextTick(function () {
- _this5.resetInputHeight();
- });
- },
- handleFocus: function handleFocus() {
- this.visible = true;
+ };
+
+ (0, _draggable2.default)(bar, dragConfig);
+ (0, _draggable2.default)(thumb, dragConfig);
+ this.update();
+ }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+/***/ },
+/* 368 */
+/***/ function(module, exports) {
+
+ module.exports={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'
+ })
+ })])
+ },staticRenderFns: []}
+
+/***/ },
+/* 369 */
+/***/ function(module, exports, __webpack_require__) {
+
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(370),
+ /* template */
+ __webpack_require__(371),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
+
+ module.exports = Component.exports
+
+
+/***/ },
+/* 370 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ exports.__esModule = true;
+
+ var _draggable = __webpack_require__(364);
+
+ var _draggable2 = _interopRequireDefault(_draggable);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ exports.default = {
+ name: 'el-color-alpha-slider',
+
+ props: {
+ color: {
+ required: true
},
- handleIconClick: function handleIconClick(event) {
- if (this.iconClass.indexOf('circle-close') > -1) {
- this.deleteSelected(event);
- } else {
- this.toggleMenu();
- }
+ vertical: Boolean
+ },
+
+ watch: {
+ 'color._alpha': function color_alpha() {
+ this.update();
},
- handleMouseDown: function handleMouseDown(event) {
- if (event.target.tagName !== 'INPUT') return;
- if (this.visible) {
- this.handleClose();
- event.preventDefault();
+ '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);
}
},
- doDestroy: function doDestroy() {
- this.$refs.popper && this.$refs.popper.doDestroy();
- this.dropdownUl = null;
- },
- 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;
+ handleDrag: function handleDrag(event) {
+ var rect = this.$el.getBoundingClientRect();
+ var thumb = this.$refs.thumb;
- 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);
+ 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));
}
},
- managePlaceholder: function managePlaceholder() {
- if (this.currentPlaceholder !== '') {
- this.currentPlaceholder = this.$refs.input.value ? '' : this.cachedPlaceHolder;
- }
+ 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);
},
- resetInputState: function resetInputState(e) {
- if (e.keyCode !== 8) this.toggleLastOptionHitState(false);
- this.inputLength = this.$refs.input.value.length * 15 + 20;
- this.resetInputHeight();
+ 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);
},
- resetInputHeight: function resetInputHeight() {
- var _this6 = this;
+ 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;
- this.$nextTick(function () {
- if (!_this6.$refs.reference) return;
- var inputChildNodes = _this6.$refs.reference.$el.childNodes;
- var input = [].filter.call(inputChildNodes, function (item) {
- return item.tagName === 'INPUT';
- })[0];
- input.style.height = Math.max(_this6.$refs.tags.clientHeight + 6, sizeMap[_this6.size] || 36) + 'px';
- if (_this6.visible && _this6.emptyText !== false) {
- _this6.broadcast('ElSelectDropdown', 'updatePopper');
- }
- });
+ return 'linear-gradient(to right, rgba(' + r + ', ' + g + ', ' + b + ', 0) 0%, rgba(' + r + ', ' + g + ', ' + b + ', 1) 100%)';
+ }
+ return null;
},
- resetHoverIndex: function resetHoverIndex() {
- var _this7 = this;
+ update: function update() {
+ this.thumbLeft = this.getThumbLeft();
+ this.thumbTop = this.getThumbTop();
+ this.background = this.getBackground();
+ }
+ },
- setTimeout(function () {
- if (!_this7.multiple) {
- _this7.hoverIndex = _this7.options.indexOf(_this7.selected);
- } else {
- if (_this7.selected.length > 0) {
- _this7.hoverIndex = Math.min.apply(null, _this7.selected.map(function (item) {
- return _this7.options.indexOf(item);
- }));
- } else {
- _this7.hoverIndex = -1;
- }
- }
- }, 300);
- },
- handleOptionSelect: function handleOptionSelect(option) {
- var _this8 = this;
+ data: function data() {
+ return {
+ thumbLeft: 0,
+ thumbTop: 0,
+ background: null
+ };
+ },
+ mounted: function mounted() {
+ var _this = 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);
- if (option.created) {
- this.query = '';
- this.inputLength = 20;
- }
- if (this.filterable) this.$refs.input.focus();
- } else {
- this.$emit('input', option.value);
- this.visible = false;
+ 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);
}
- this.$nextTick(function () {
- return _this8.scrollToOption(option);
- });
- },
- getValueIndex: function getValueIndex() {
- var _this9 = this;
+ };
- var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var value = arguments[1];
+ (0, _draggable2.default)(bar, dragConfig);
+ (0, _draggable2.default)(thumb, dragConfig);
+ this.update();
+ }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
- if (!isObject) {
- return arr.indexOf(value);
- } else {
- var _ret = function () {
- var valueKey = _this9.valueKey;
- var index = -1;
- arr.some(function (item, i) {
- if ((0, _util.getValueByPath)(item, valueKey) === (0, _util.getValueByPath)(value, valueKey)) {
- index = i;
- return true;
- }
- return false;
- });
- return {
- v: index
- };
- }();
+/***/ },
+/* 371 */
+/***/ function(module, exports) {
- if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
- }
- },
- toggleMenu: function toggleMenu() {
- if (this.filterable && this.query === '' && this.visible) {
- return;
- }
- if (!this.disabled) {
- this.visible = !this.visible;
- }
- },
- navigateOptions: function navigateOptions(direction) {
- var _this10 = this;
+ module.exports={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'
+ })
+ })])
+ },staticRenderFns: []}
- if (!this.visible) {
- this.visible = true;
- return;
- }
- if (this.options.length === 0 || this.filteredOptionsCount === 0) return;
- this.optionsAllDisabled = this.options.length === this.options.filter(function (item) {
- return item.disabled === true;
- }).length;
- if (!this.optionsAllDisabled) {
- if (direction === 'next') {
- this.hoverIndex++;
- if (this.hoverIndex === this.options.length) {
- this.hoverIndex = 0;
- }
- if (this.options[this.hoverIndex].disabled === true || this.options[this.hoverIndex].groupDisabled === true || !this.options[this.hoverIndex].visible) {
- this.navigateOptions('next');
- }
- }
- if (direction === 'prev') {
- this.hoverIndex--;
- if (this.hoverIndex < 0) {
- this.hoverIndex = this.options.length - 1;
- }
- if (this.options[this.hoverIndex].disabled === true || this.options[this.hoverIndex].groupDisabled === true || !this.options[this.hoverIndex].visible) {
- this.navigateOptions('prev');
- }
- }
- }
- this.$nextTick(function () {
- return _this10.scrollToOption(_this10.options[_this10.hoverIndex]);
- });
- },
- selectOption: function selectOption() {
- if (this.options[this.hoverIndex]) {
- this.handleOptionSelect(this.options[this.hoverIndex]);
- }
+/***/ },
+/* 372 */
+/***/ function(module, exports) {
+
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('transition', {
+ attrs: {
+ "name": "el-zoom-in-top"
},
- deleteSelected: function deleteSelected(event) {
- event.stopPropagation();
- this.$emit('input', '');
- this.visible = false;
- this.$emit('clear');
+ 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"
},
- deleteTag: function deleteTag(event, tag) {
- var index = this.selected.indexOf(tag);
- if (index > -1 && !this.disabled) {
- var value = this.value.slice();
- value.splice(index, 1);
- this.$emit('input', value);
- this.$emit('remove-tag', tag);
- }
- event.stopPropagation();
+ 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(), _c('div', {
+ staticClass: "el-color-dropdown__btns"
+ }, [_c('span', {
+ staticClass: "el-color-dropdown__value"
+ }, [_vm._v(_vm._s(_vm.currentColor))]), _c('a', {
+ staticClass: "el-color-dropdown__link-btn",
+ attrs: {
+ "href": "JavaScript:"
},
- onInputChange: function onInputChange() {
- if (this.filterable) {
- this.query = this.selectedLabel;
+ on: {
+ "click": function($event) {
+ _vm.$emit('clear')
}
- },
- onOptionDestroy: function onOptionDestroy(option) {
- this.optionsCount--;
- this.filteredOptionsCount--;
- var index = this.options.indexOf(option);
- if (index > -1) {
- this.options.splice(index, 1);
+ }
+ }, [_vm._v(_vm._s(_vm.t('el.colorpicker.clear')))]), _c('button', {
+ staticClass: "el-color-dropdown__btn",
+ on: {
+ "click": _vm.confirmValue
+ }
+ }, [_vm._v(_vm._s(_vm.t('el.colorpicker.confirm')))])])], 1)])
+ },staticRenderFns: []}
+
+/***/ },
+/* 373 */
+/***/ function(module, exports) {
+
+ module.exports={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"
+ }],
+ staticClass: "el-color-picker"
+ }, [_c('div', {
+ staticClass: "el-color-picker__trigger",
+ on: {
+ "click": function($event) {
+ _vm.showPicker = !_vm.showPicker
}
- this.broadcast('ElOption', 'resetIndex');
- },
- resetInputWidth: function resetInputWidth() {
- this.inputWidth = this.$refs.reference.$el.getBoundingClientRect().width;
- },
- handleResize: function handleResize() {
- this.resetInputWidth();
- if (this.multiple) this.resetInputHeight();
+ }
+ }, [_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', {
+ staticClass: "el-color-picker__icon el-icon-caret-bottom"
+ })]), _c('picker-dropdown', {
+ ref: "dropdown",
+ staticClass: "el-color-picker__panel",
+ attrs: {
+ "color": _vm.color,
+ "show-alpha": _vm.showAlpha
},
- checkDefaultFirstOption: function checkDefaultFirstOption() {
- this.hoverIndex = -1;
- for (var i = 0; i !== this.options.length; ++i) {
- var option = this.options[i];
- if (this.query) {
- // pick first options that passes the filter
- if (!option.disabled && !option.groupDisabled && option.visible) {
- this.hoverIndex = i;
- break;
- }
- } else {
- // pick currently selected option
- if (option.itemSelected) {
- this.hoverIndex = i;
- break;
- }
- }
- }
+ on: {
+ "pick": _vm.confirmValue,
+ "clear": _vm.clearValue
},
- getValueKey: function getValueKey(item) {
- var type = _typeof(item.value);
- if (type === 'number' || type === 'string') {
- return item.value;
- } else {
- return (0, _util.getValueByPath)(item.value, this.valueKey);
- }
+ model: {
+ value: (_vm.showPicker),
+ callback: function($$v) {
+ _vm.showPicker = $$v
+ },
+ expression: "showPicker"
}
- },
+ })], 1)
+ },staticRenderFns: []}
- created: function created() {
- var _this11 = this;
+/***/ },
+/* 374 */
+/***/ function(module, exports, __webpack_require__) {
- 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.setSelected();
+ 'use strict';
- this.debouncedOnInputChange = (0, _debounce2.default)(this.debounce, function () {
- _this11.onInputChange();
- });
+ exports.__esModule = true;
- this.$on('handleOptionClick', this.handleOptionSelect);
- this.$on('onOptionDestroy', this.onOptionDestroy);
- this.$on('setSelected', this.setSelected);
- },
- mounted: function mounted() {
- var _this12 = this;
+ var _main = __webpack_require__(375);
- if (this.multiple && Array.isArray(this.value) && this.value.length > 0) {
- this.currentPlaceholder = '';
- }
- (0, _resizeEvent.addResizeListener)(this.$el, this.handleResize);
- if (this.remote && this.multiple) {
- this.resetInputHeight();
- }
- this.$nextTick(function () {
- if (_this12.$refs.reference && _this12.$refs.reference.$el) {
- _this12.inputWidth = _this12.$refs.reference.$el.getBoundingClientRect().width;
- }
- });
- },
- beforeDestroy: function beforeDestroy() {
- if (this.$el && this.handleResize) (0, _resizeEvent.removeResizeListener)(this.$el, this.handleResize);
- }
+ var _main2 = _interopRequireDefault(_main);
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+ /* istanbul ignore next */
+ _main2.default.install = function (Vue) {
+ Vue.component(_main2.default.name, _main2.default);
};
-/***/ },
+ exports.default = _main2.default;
-/***/ 267:
+/***/ },
+/* 375 */
/***/ function(module, exports, __webpack_require__) {
- var Component = __webpack_require__(3)(
+ var Component = __webpack_require__(5)(
/* script */
- __webpack_require__(268),
+ __webpack_require__(376),
/* template */
- __webpack_require__(269),
+ __webpack_require__(380),
/* styles */
null,
/* scopeId */
@@ -63098,76 +62603,64 @@ module.exports =
/***/ },
-
-/***/ 268:
+/* 376 */
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _vuePopper = __webpack_require__(13);
-
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = {
- name: 'ElSelectDropdown',
-
- componentName: 'ElSelectDropdown',
-
- mixins: [_vuePopper2.default],
+ var _button = __webpack_require__(31);
- props: {
- placement: {
- default: 'bottom-start'
- },
+ var _button2 = _interopRequireDefault(_button);
- boundariesPadding: {
- default: 0
- },
+ var _emitter = __webpack_require__(15);
- popperOptions: {
- default: function _default() {
- return {
- forceAbsolute: true,
- gpuAcceleration: false
- };
- }
- }
- },
+ var _emitter2 = _interopRequireDefault(_emitter);
- data: function data() {
- return {
- minWidth: ''
- };
- },
+ var _locale = __webpack_require__(10);
+ var _locale2 = _interopRequireDefault(_locale);
- computed: {
- popperClass: function popperClass() {
- return this.$parent.popperClass;
- }
- },
+ var _transferPanel = __webpack_require__(377);
- watch: {
- '$parent.inputWidth': function $parentInputWidth() {
- this.minWidth = this.$parent.$el.getBoundingClientRect().width + 'px';
- }
- },
+ var _transferPanel2 = _interopRequireDefault(_transferPanel);
- mounted: function mounted() {
- var _this = this;
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- 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);
- }
- }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
//
//
//
@@ -63177,2149 +62670,1847 @@ module.exports =
//
//
-/***/ },
+ exports.default = {
+ name: 'ElTransfer',
-/***/ 269:
-/***/ function(module, exports) {
+ mixins: [_emitter2.default, _locale2.default],
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-select-dropdown",
- class: [{
- 'is-multiple': _vm.$parent.multiple
- }, _vm.popperClass],
- style: ({
- minWidth: _vm.minWidth
- })
- }, [_vm._t("default")], 2)
- },staticRenderFns: []}
-
-/***/ },
-
-/***/ 270:
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(26);
-
-/***/ },
-
-/***/ 271:
-/***/ function(module, exports) {
+ components: {
+ TransferPanel: _transferPanel2.default,
+ ElButton: _button2.default
+ },
- module.exports={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"
- }, [(_vm.multiple) ? _c('div', {
- ref: "tags",
- staticClass: "el-select__tags",
- style: ({
- 'max-width': _vm.inputWidth - 32 + 'px'
- }),
- on: {
- "click": function($event) {
- $event.stopPropagation();
- _vm.toggleMenu($event)
- }
- }
- }, [_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.disabled,
- "hit": item.hitState,
- "type": "primary",
- "close-transition": ""
- },
- on: {
- "close": function($event) {
- _vm.deleteTag($event, item)
- }
+ props: {
+ data: {
+ type: Array,
+ default: function _default() {
+ return [];
}
- }, [_c('span', {
- staticClass: "el-select__tags-text"
- }, [_vm._v(_vm._s(item.currentLabel))])])
- })), (_vm.filterable) ? _c('input', {
- directives: [{
- name: "model",
- rawName: "v-model",
- value: (_vm.query),
- expression: "query"
- }],
- ref: "input",
- staticClass: "el-select__input",
- class: ("is-" + _vm.size),
- style: ({
- width: _vm.inputLength + 'px',
- 'max-width': _vm.inputWidth - 42 + 'px'
- }),
- attrs: {
- "type": "text",
- "disabled": _vm.disabled,
- "debounce": _vm.remote ? 300 : 0
},
- domProps: {
- "value": (_vm.query)
+ titles: {
+ type: Array,
+ default: function _default() {
+ return [];
+ }
},
- on: {
- "focus": function($event) {
- _vm.visible = true
- },
- "keyup": _vm.managePlaceholder,
- "keydown": [_vm.resetInputState, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
- $event.preventDefault();
- _vm.navigateOptions('next')
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
- $event.preventDefault();
- _vm.navigateOptions('prev')
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
- $event.preventDefault();
- _vm.selectOption($event)
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "esc", 27)) { return null; }
- $event.stopPropagation();
- $event.preventDefault();
- _vm.visible = false
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "delete", [8, 46])) { return null; }
- _vm.deletePrevTag($event)
- }],
- "input": function($event) {
- if ($event.target.composing) { return; }
- _vm.query = $event.target.value
+ buttonTexts: {
+ type: Array,
+ default: function _default() {
+ return [];
}
- }
- }) : _vm._e()], 1) : _vm._e(), _c('el-input', {
- ref: "reference",
- attrs: {
- "type": "text",
- "placeholder": _vm.currentPlaceholder,
- "name": _vm.name,
- "size": _vm.size,
- "disabled": _vm.disabled,
- "readonly": !_vm.filterable || _vm.multiple,
- "validate-event": false,
- "icon": _vm.iconClass
},
- on: {
- "focus": _vm.handleFocus,
- "click": _vm.handleIconClick
+ filterPlaceholder: {
+ type: String,
+ default: ''
},
- nativeOn: {
- "mousedown": function($event) {
- _vm.handleMouseDown($event)
- },
- "keyup": function($event) {
- _vm.debouncedOnInputChange($event)
- },
- "keydown": [function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
- $event.preventDefault();
- _vm.navigateOptions('next')
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
- $event.preventDefault();
- _vm.navigateOptions('prev')
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
- $event.preventDefault();
- _vm.selectOption($event)
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "esc", 27)) { return null; }
- $event.stopPropagation();
- $event.preventDefault();
- _vm.visible = false
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "tab", 9)) { return null; }
- _vm.visible = false
- }],
- "paste": function($event) {
- _vm.debouncedOnInputChange($event)
- },
- "mouseenter": function($event) {
- _vm.inputHovering = true
- },
- "mouseleave": function($event) {
- _vm.inputHovering = false
+ filterMethod: Function,
+ leftDefaultChecked: {
+ type: Array,
+ default: function _default() {
+ return [];
}
},
- model: {
- value: (_vm.selectedLabel),
- callback: function($$v) {
- _vm.selectedLabel = $$v
- },
- expression: "selectedLabel"
- }
- }), _c('transition', {
- attrs: {
- "name": "el-zoom-in-top"
+ rightDefaultChecked: {
+ type: Array,
+ default: function _default() {
+ return [];
+ }
},
- 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"
- }, [_c('el-scrollbar', {
- directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.options.length > 0 && !_vm.loading),
- expression: "options.length > 0 && !loading"
- }],
- class: {
- 'is-empty': !_vm.allowCreate && _vm.filteredOptionsCount === 0
+ renderContent: Function,
+ value: {
+ type: Array,
+ default: function _default() {
+ return [];
+ }
},
- 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": ""
+ footerFormat: {
+ type: Object,
+ default: function _default() {
+ return {};
+ }
+ },
+ filterable: Boolean,
+ props: {
+ type: Object,
+ default: function _default() {
+ return {
+ label: 'label',
+ key: 'key',
+ disabled: 'disabled'
+ };
+ }
}
- }) : _vm._e(), _vm._t("default")], 2), (_vm.emptyText && (_vm.allowCreate && _vm.options.length === 0 || !_vm.allowCreate)) ? _c('p', {
- staticClass: "el-select-dropdown__empty"
- }, [_vm._v(_vm._s(_vm.emptyText))]) : _vm._e()], 1)], 1)], 1)
- },staticRenderFns: []}
-
-/***/ }
+ },
-/******/ });
+ data: function data() {
+ return {
+ leftChecked: [],
+ rightChecked: []
+ };
+ },
-/***/ }),
-/* 42 */
-/***/ (function(module, exports, __webpack_require__) {
-"use strict";
+ computed: {
+ 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;
-exports.__esModule = true;
+ return this.data.filter(function (item) {
+ return _this2.value.indexOf(item[_this2.props.key]) > -1;
+ });
+ }
+ },
-var _vue = __webpack_require__(3);
+ watch: {
+ value: function value(val) {
+ this.dispatch('ElFormItem', 'el.form.change', val);
+ }
+ },
-var _vue2 = _interopRequireDefault(_vue);
+ methods: {
+ onSourceCheckedChange: function onSourceCheckedChange(val) {
+ this.leftChecked = val;
+ },
+ onTargetCheckedChange: function onTargetCheckedChange(val) {
+ this.rightChecked = val;
+ },
+ 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 _dom = __webpack_require__(4);
+ var currentValue = this.value.slice();
+ this.leftChecked.forEach(function (item) {
+ if (_this3.value.indexOf(item) === -1) {
+ currentValue = currentValue.concat(item);
+ }
+ });
+ this.$emit('input', currentValue);
+ this.$emit('change', currentValue, 'right', this.leftChecked);
+ }
+ }
+ };
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+/***/ },
+/* 377 */
+/***/ function(module, exports, __webpack_require__) {
-var hasModal = false;
+ var Component = __webpack_require__(5)(
+ /* script */
+ __webpack_require__(378),
+ /* template */
+ __webpack_require__(379),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
-var getModal = function getModal() {
- if (_vue2.default.prototype.$isServer) return;
- var modalDom = PopupManager.modalDom;
- if (modalDom) {
- hasModal = true;
- } else {
- hasModal = false;
- modalDom = document.createElement('div');
- PopupManager.modalDom = modalDom;
+ module.exports = Component.exports
- modalDom.addEventListener('touchmove', function (event) {
- event.preventDefault();
- event.stopPropagation();
- });
- modalDom.addEventListener('click', function () {
- PopupManager.doOnModalClick && PopupManager.doOnModalClick();
- });
- }
+/***/ },
+/* 378 */
+/***/ function(module, exports, __webpack_require__) {
- return modalDom;
-};
+ 'use strict';
-var instances = {};
+ exports.__esModule = true;
-var PopupManager = {
- zIndex: 2000,
+ var _checkboxGroup = __webpack_require__(143);
- modalFade: true,
+ var _checkboxGroup2 = _interopRequireDefault(_checkboxGroup);
- getInstance: function getInstance(id) {
- return instances[id];
- },
+ var _checkbox = __webpack_require__(130);
- register: function register(id, instance) {
- if (id && instance) {
- instances[id] = instance;
- }
- },
+ var _checkbox2 = _interopRequireDefault(_checkbox);
- deregister: function deregister(id) {
- if (id) {
- instances[id] = null;
- delete instances[id];
- }
- },
+ var _input = __webpack_require__(20);
- nextZIndex: function nextZIndex() {
- return PopupManager.zIndex++;
- },
+ var _input2 = _interopRequireDefault(_input);
- modalStack: [],
+ var _locale = __webpack_require__(10);
- doOnModalClick: function doOnModalClick() {
- var topItem = PopupManager.modalStack[PopupManager.modalStack.length - 1];
- if (!topItem) return;
+ var _locale2 = _interopRequireDefault(_locale);
- var instance = PopupManager.getInstance(topItem.id);
- if (instance && instance.closeOnClickModal) {
- instance.close();
- }
- },
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- openModal: function openModal(id, zIndex, dom, modalClass, modalFade) {
- if (_vue2.default.prototype.$isServer) return;
- if (!id || zIndex === undefined) return;
- this.modalFade = modalFade;
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var modalStack = this.modalStack;
+ exports.default = {
+ mixins: [_locale2.default],
- for (var i = 0, j = modalStack.length; i < j; i++) {
- var item = modalStack[i];
- if (item.id === id) {
- return;
- }
- }
+ name: 'ElTransferPanel',
- var modalDom = getModal();
+ componentName: 'ElTransferPanel',
- (0, _dom.addClass)(modalDom, 'v-modal');
- if (this.modalFade && !hasModal) {
- (0, _dom.addClass)(modalDom, 'v-modal-enter');
- }
- if (modalClass) {
- var classArr = modalClass.trim().split(/\s+/);
- classArr.forEach(function (item) {
- return (0, _dom.addClass)(modalDom, item);
- });
- }
- setTimeout(function () {
- (0, _dom.removeClass)(modalDom, 'v-modal-enter');
- }, 200);
+ components: {
+ ElCheckboxGroup: _checkboxGroup2.default,
+ ElCheckbox: _checkbox2.default,
+ ElInput: _input2.default,
+ 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 parent = getParent(this);
+ return parent.renderContent ? parent.renderContent(h, this.option) : h(
+ 'span',
+ null,
+ [this.option[parent.labelProp] || this.option[parent.keyProp]]
+ );
+ }
+ }
+ },
- if (dom && dom.parentNode && dom.parentNode.nodeType !== 11) {
- dom.parentNode.appendChild(modalDom);
- } else {
- document.body.appendChild(modalDom);
- }
+ props: {
+ data: {
+ type: Array,
+ default: function _default() {
+ return [];
+ }
+ },
+ renderContent: Function,
+ placeholder: String,
+ title: String,
+ filterable: Boolean,
+ footerFormat: Object,
+ filterMethod: Function,
+ defaultChecked: Array,
+ props: Object
+ },
- if (zIndex) {
- modalDom.style.zIndex = zIndex;
- }
- modalDom.style.display = '';
+ data: function data() {
+ return {
+ checked: [],
+ allChecked: false,
+ query: '',
+ inputHover: false
+ };
+ },
- this.modalStack.push({ id: id, zIndex: zIndex, modalClass: modalClass });
- },
- closeModal: function closeModal(id) {
- var modalStack = this.modalStack;
- var modalDom = getModal();
+ watch: {
+ checked: function checked(val) {
+ this.updateAllChecked();
+ this.$emit('checked-change', val);
+ },
+ data: function data() {
+ var _this = this;
- if (modalStack.length > 0) {
- var topItem = modalStack[modalStack.length - 1];
- if (topItem.id === id) {
- if (topItem.modalClass) {
- var classArr = topItem.modalClass.trim().split(/\s+/);
- classArr.forEach(function (item) {
- return (0, _dom.removeClass)(modalDom, item);
- });
- }
+ 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.checked = checked;
+ },
+ checkableData: function checkableData() {
+ this.updateAllChecked();
+ },
- modalStack.pop();
- if (modalStack.length > 0) {
- modalDom.style.zIndex = modalStack[modalStack.length - 1].zIndex;
- }
- } else {
- for (var i = modalStack.length - 1; i >= 0; i--) {
- if (modalStack[i].id === id) {
- modalStack.splice(i, 1);
- break;
- }
- }
- }
- }
- if (modalStack.length === 0) {
- if (this.modalFade) {
- (0, _dom.addClass)(modalDom, 'v-modal-leave');
- }
- setTimeout(function () {
- if (modalStack.length === 0) {
- if (modalDom.parentNode) modalDom.parentNode.removeChild(modalDom);
- modalDom.style.display = 'none';
- PopupManager.modalDom = undefined;
- }
- (0, _dom.removeClass)(modalDom, 'v-modal-leave');
- }, 200);
- }
- }
-};
+ defaultChecked: {
+ immediate: true,
+ handler: function handler(val, oldVal) {
+ var _this2 = this;
-var getTopPopup = function getTopPopup() {
- if (_vue2.default.prototype.$isServer) return;
- if (PopupManager.modalStack.length > 0) {
- var topPopup = PopupManager.modalStack[PopupManager.modalStack.length - 1];
- if (!topPopup) return;
- var instance = PopupManager.getInstance(topPopup.id);
+ 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.checked = checked;
+ }
+ }
+ },
- return instance;
- }
-};
+ computed: {
+ filteredData: function filteredData() {
+ var _this3 = this;
-if (!_vue2.default.prototype.$isServer) {
- // handle `esc` key when the popup is shown
- window.addEventListener('keydown', function (event) {
- if (event.keyCode === 27) {
- var topPopup = getTopPopup();
+ 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;
- if (topPopup && topPopup.closeOnPressEscape) {
- topPopup.handleClose ? topPopup.handleClose() : topPopup.handleAction ? topPopup.handleAction('cancel') : topPopup.close();
- }
- }
- });
-}
+ return this.filteredData.filter(function (item) {
+ return !item[_this4.disabledProp];
+ });
+ },
+ checkedSummary: function checkedSummary() {
+ var checkedLength = this.checked.length;
+ var dataLength = this.data.length;
+ var _footerFormat = this.footerFormat,
+ noChecked = _footerFormat.noChecked,
+ hasChecked = _footerFormat.hasChecked;
-exports.default = PopupManager;
+ if (noChecked && hasChecked) {
+ return checkedLength > 0 ? hasChecked.replace(/\${checked}/g, checkedLength).replace(/\${total}/g, dataLength) : noChecked.replace(/\${total}/g, dataLength);
+ } else {
+ return checkedLength > 0 ? this.t('el.transfer.hasCheckedFormat', { total: dataLength, checked: checkedLength }) : this.t('el.transfer.noCheckedFormat', { total: 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';
+ }
+ },
+
+ 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.target.checked ? this.checkableData.map(function (item) {
+ return item[_this6.keyProp];
+ }) : [];
+ },
+ clearQuery: function clearQuery() {
+ if (this.inputIcon === 'circle-close') {
+ this.query = '';
+ }
+ }
+ }
+ };
+
+/***/ },
+/* 379 */
+/***/ function(module, exports) {
+
+ module.exports={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"
+ }, [_vm._v(_vm._s(_vm.title))]), _c('div', {
+ staticClass: "el-transfer-panel__body"
+ }, [(_vm.filterable) ? _c('el-input', {
+ staticClass: "el-transfer-panel__filter",
+ attrs: {
+ "size": "small",
+ "placeholder": _vm.placeholder,
+ "icon": _vm.inputIcon
+ },
+ on: {
+ "click": _vm.clearQuery
+ },
+ 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"
+ }
+ }) : _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)
+ })), _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), _c('p', {
+ staticClass: "el-transfer-panel__footer"
+ }, [_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(_vm._s(_vm.checkedSummary))]), _vm._t("default")], 2)])
+ },staticRenderFns: []}
+
+/***/ },
+/* 380 */
+/***/ function(module, exports) {
+
+ module.exports={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({
+ 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), [_vm._t("left-footer")], 2), _c('div', {
+ staticClass: "el-transfer__buttons"
+ }, [_c('el-button', {
+ attrs: {
+ "type": "primary",
+ "size": "small",
+ "disabled": _vm.rightChecked.length === 0
+ },
+ nativeOn: {
+ "click": function($event) {
+ _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', {
+ attrs: {
+ "type": "primary",
+ "size": "small",
+ "disabled": _vm.leftChecked.length === 0
+ },
+ nativeOn: {
+ "click": function($event) {
+ _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({
+ 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), [_vm._t("right-footer")], 2)], 1)
+ },staticRenderFns: []}
+
+/***/ }
+/******/ ]);
/***/ }),
-/* 43 */
+/* 42 */
/***/ (function(module, exports, __webpack_require__) {
-"use strict";
-var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;
+module.exports =
+/******/ (function(modules) { // webpackBootstrap
+/******/ // The module cache
+/******/ var installedModules = {};
-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; };
+/******/ // The require function
+/******/ function __webpack_require__(moduleId) {
-/**
- * @fileOverview Kickass library to create and place poppers near their reference elements.
- * @version {{version}}
- * @license
- * Copyright (c) 2016 Federico Zivolo and contributors
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- */
+/******/ // Check if module is in cache
+/******/ if(installedModules[moduleId])
+/******/ return installedModules[moduleId].exports;
-//
-// Cross module loader
-// Supported: Node, AMD, Browser globals
-//
-;(function (root, factory) {
- if (true) {
- // AMD. Register as an anonymous module.
- !(__WEBPACK_AMD_DEFINE_FACTORY__ = (factory),
- __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?
- (__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :
- __WEBPACK_AMD_DEFINE_FACTORY__),
- __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
- } else if ((typeof module === 'undefined' ? 'undefined' : _typeof(module)) === 'object' && module.exports) {
- // Node. Does not work with strict CommonJS, but
- // only CommonJS-like environments that support module.exports,
- // like Node.
- module.exports = factory();
- } else {
- // Browser globals (root is window)
- root.Popper = factory();
- }
-})(undefined, function () {
+/******/ // Create a new module (and put it into the cache)
+/******/ var module = installedModules[moduleId] = {
+/******/ exports: {},
+/******/ id: moduleId,
+/******/ loaded: false
+/******/ };
- 'use strict';
+/******/ // Execute the module function
+/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- var root = window;
+/******/ // Flag the module as loaded
+/******/ module.loaded = true;
- // default options
- var DEFAULTS = {
- // placement of the popper
- placement: 'bottom',
+/******/ // Return the exports of the module
+/******/ return module.exports;
+/******/ }
- gpuAcceleration: true,
- // shift popper from its origin by the given amount of pixels (can be negative)
- offset: 0,
+/******/ // expose the modules object (__webpack_modules__)
+/******/ __webpack_require__.m = modules;
- // the element which will act as boundary of the popper
- boundariesElement: 'viewport',
+/******/ // expose the module cache
+/******/ __webpack_require__.c = installedModules;
- // amount of pixel used to define a minimum distance between the boundaries and the popper
- boundariesPadding: 5,
+/******/ // __webpack_public_path__
+/******/ __webpack_require__.p = "/dist/";
- // popper will try to prevent overflow following this order,
- // by default, then, it could overflow on the left and on top of the boundariesElement
- preventOverflowOrder: ['left', 'right', 'top', 'bottom'],
+/******/ // Load entry module and return exports
+/******/ return __webpack_require__(0);
+/******/ })
+/************************************************************************/
+/******/ ({
- // the behavior used by flip to change the placement of the popper
- flipBehavior: 'flip',
+/***/ 0:
+/***/ function(module, exports, __webpack_require__) {
- arrowElement: '[x-arrow]',
+ module.exports = __webpack_require__(264);
- // list of functions used to modify the offsets before they are applied to the popper
- modifiers: ['shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle'],
- modifiersIgnored: [],
+/***/ },
- forceAbsolute: false
- };
+/***/ 3:
+/***/ function(module, exports) {
- /**
- * Create a new Popper.js instance
- * @constructor Popper
- * @param {HTMLElement} reference - The reference element used to position the popper
- * @param {HTMLElement|Object} popper
- * The HTML element used as popper, or a configuration used to generate the popper.
- * @param {String} [popper.tagName='div'] The tag name of the generated popper.
- * @param {Array} [popper.classNames=['popper']] Array of classes to apply to the generated popper.
- * @param {Array} [popper.attributes] Array of attributes to apply, specify `attr:value` to assign a value to it.
- * @param {HTMLElement|String} [popper.parent=window.document.body] The parent element, given as HTMLElement or as query string.
- * @param {String} [popper.content=''] The content of the popper, it can be text, html, or node; if it is not text, set `contentType` to `html` or `node`.
- * @param {String} [popper.contentType='text'] If `html`, the `content` will be parsed as HTML. If `node`, it will be appended as-is.
- * @param {String} [popper.arrowTagName='div'] Same as `popper.tagName` but for the arrow element.
- * @param {Array} [popper.arrowClassNames='popper__arrow'] Same as `popper.classNames` but for the arrow element.
- * @param {String} [popper.arrowAttributes=['x-arrow']] Same as `popper.attributes` but for the arrow element.
- * @param {Object} options
- * @param {String} [options.placement=bottom]
- * Placement of the popper accepted values: `top(-start, -end), right(-start, -end), bottom(-start, -right),
- * left(-start, -end)`
- *
- * @param {HTMLElement|String} [options.arrowElement='[x-arrow]']
- * The DOM Node used as arrow for the popper, or a CSS selector used to get the DOM node. It must be child of
- * its parent Popper. Popper.js will apply to the given element the style required to align the arrow with its
- * reference element.
- * By default, it will look for a child node of the popper with the `x-arrow` attribute.
- *
- * @param {Boolean} [options.gpuAcceleration=true]
- * When this property is set to true, the popper position will be applied using CSS3 translate3d, allowing the
- * browser to use the GPU to accelerate the rendering.
- * If set to false, the popper will be placed using `top` and `left` properties, not using the GPU.
- *
- * @param {Number} [options.offset=0]
- * Amount of pixels the popper will be shifted (can be negative).
- *
- * @param {String|Element} [options.boundariesElement='viewport']
- * The element which will define the boundaries of the popper position, the popper will never be placed outside
- * of the defined boundaries (except if `keepTogether` is enabled)
- *
- * @param {Number} [options.boundariesPadding=5]
- * Additional padding for the boundaries
- *
- * @param {Array} [options.preventOverflowOrder=['left', 'right', 'top', 'bottom']]
- * Order used when Popper.js tries to avoid overflows from the boundaries, they will be checked in order,
- * this means that the last ones will never overflow
- *
- * @param {String|Array} [options.flipBehavior='flip']
- * The behavior used by the `flip` modifier to change the placement of the popper when the latter is trying to
- * overlap its reference element. Defining `flip` as value, the placement will be flipped on
- * its axis (`right - left`, `top - bottom`).
- * You can even pass an array of placements (eg: `['right', 'left', 'top']` ) to manually specify
- * how alter the placement when a flip is needed. (eg. in the above example, it would first flip from right to left,
- * then, if even in its new placement, the popper is overlapping its reference element, it will be moved to top)
- *
- * @param {Array} [options.modifiers=[ 'shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle']]
- * List of functions used to modify the data before they are applied to the popper, add your custom functions
- * to this array to edit the offsets and placement.
- * The function should reflect the @params and @returns of preventOverflow
- *
- * @param {Array} [options.modifiersIgnored=[]]
- * Put here any built-in modifier name you want to exclude from the modifiers list
- * The function should reflect the @params and @returns of preventOverflow
- *
- * @param {Boolean} [options.removeOnDestroy=false]
- * Set to true if you want to automatically remove the popper when you call the `destroy` method.
- */
- function Popper(reference, popper, options) {
- this._reference = reference.jquery ? reference[0] : reference;
- this.state = {};
+ /* globals __VUE_SSR_CONTEXT__ */
- // if the popper variable is a configuration object, parse it to generate an HTMLElement
- // generate a default popper if is not defined
- var isNotDefined = typeof popper === 'undefined' || popper === null;
- var isConfig = popper && Object.prototype.toString.call(popper) === '[object Object]';
- if (isNotDefined || isConfig) {
- this._popper = this.parse(isConfig ? popper : {});
- }
- // otherwise, use the given HTMLElement as popper
- else {
- this._popper = popper.jquery ? popper[0] : popper;
- }
+ // this module is a runtime utility for cleaner component module output and will
+ // be included in the final webpack user bundle
- // with {} we create a new object with the options inside it
- this._options = Object.assign({}, DEFAULTS, options);
+ module.exports = function normalizeComponent (
+ rawScriptExports,
+ compiledTemplate,
+ injectStyles,
+ scopeId,
+ moduleIdentifier /* server only */
+ ) {
+ var esModule
+ var scriptExports = rawScriptExports = rawScriptExports || {}
- // refactoring modifiers' list
- this._options.modifiers = this._options.modifiers.map(function (modifier) {
- // remove ignored modifiers
- if (this._options.modifiersIgnored.indexOf(modifier) !== -1) return;
+ // ES6 modules interop
+ var type = typeof rawScriptExports.default
+ if (type === 'object' || type === 'function') {
+ esModule = rawScriptExports
+ scriptExports = rawScriptExports.default
+ }
- // set the x-placement attribute before everything else because it could be used to add margins to the popper
- // margins needs to be calculated to get the correct popper offsets
- if (modifier === 'applyStyle') {
- this._popper.setAttribute('x-placement', this._options.placement);
- }
+ // Vue.extend constructor export interop
+ var options = typeof scriptExports === 'function'
+ ? scriptExports.options
+ : scriptExports
- // return predefined modifier identified by string or keep the custom one
- return this.modifiers[modifier] || modifier;
- }.bind(this));
+ // render functions
+ if (compiledTemplate) {
+ options.render = compiledTemplate.render
+ options.staticRenderFns = compiledTemplate.staticRenderFns
+ }
- // make sure to apply the popper position before any computation
- this.state.position = this._getPosition(this._popper, this._reference);
- setStyle(this._popper, { position: this.state.position, top: 0 });
+ // scopedId
+ if (scopeId) {
+ options._scopeId = scopeId
+ }
- // fire the first update to position the popper in the right place
- this.update();
+ var hook
+ if (moduleIdentifier) { // server build
+ hook = function (context) {
+ // 2.3 injection
+ context = context || (this.$vnode && this.$vnode.ssrContext)
+ // 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 = injectStyles
+ }
- // setup event listeners, they will take care of update the position in specific situations
- this._setupEventListeners();
- return this;
- }
+ if (hook) {
+ // inject component registration as beforeCreate hook
+ var existing = options.beforeCreate
+ options.beforeCreate = existing
+ ? [].concat(existing, hook)
+ : [hook]
+ }
- //
- // Methods
- //
- /**
- * Destroy the popper
- * @method
- * @memberof Popper
- */
- Popper.prototype.destroy = function () {
- this._popper.removeAttribute('x-placement');
- this._popper.style.left = '';
- this._popper.style.position = '';
- this._popper.style.top = '';
- this._popper.style[getSupportedPropertyName('transform')] = '';
- this._removeEventListeners();
+ return {
+ esModule: esModule,
+ exports: scriptExports,
+ options: options
+ }
+ }
- // remove the popper if user explicity asked for the deletion on destroy
- if (this._options.removeOnDestroy) {
- this._popper.remove();
- }
- return this;
- };
- /**
- * Updates the position of the popper, computing the new offsets and applying the new style
- * @method
- * @memberof Popper
- */
- Popper.prototype.update = function () {
- var data = { instance: this, styles: {} };
+/***/ },
- // store placement inside the data object, modifiers will be able to edit `placement` if needed
- // and refer to _originalPlacement to know the original value
- data.placement = this._options.placement;
- data._originalPlacement = this._options.placement;
+/***/ 9:
+/***/ function(module, exports) {
- // compute the popper and reference offsets and put them inside data.offsets
- data.offsets = this._getOffsets(this._popper, this._reference, data.placement);
+ module.exports = __webpack_require__(11);
- // get boundaries
- data.boundaries = this._getBoundaries(data, this._options.boundariesPadding, this._options.boundariesElement);
+/***/ },
- data = this.runModifiers(data, this._options.modifiers);
+/***/ 10:
+/***/ function(module, exports) {
- if (typeof this.state.updateCallback === 'function') {
- this.state.updateCallback(data);
- }
- };
+ module.exports = __webpack_require__(20);
- /**
- * If a function is passed, it will be executed after the initialization of popper with as first argument the Popper instance.
- * @method
- * @memberof Popper
- * @param {Function} callback
- */
- Popper.prototype.onCreate = function (callback) {
- // the createCallbacks return as first argument the popper instance
- callback(this);
- return this;
- };
+/***/ },
- /**
- * If a function is passed, it will be executed after each update of popper with as first argument the set of coordinates and informations
- * used to style popper and its arrow.
- * NOTE: it doesn't get fired on the first call of the `Popper.update()` method inside the `Popper` constructor!
- * @method
- * @memberof Popper
- * @param {Function} callback
- */
- Popper.prototype.onUpdate = function (callback) {
- this.state.updateCallback = callback;
- return this;
- };
+/***/ 13:
+/***/ function(module, exports) {
- /**
- * Helper used to generate poppers from a configuration file
- * @method
- * @memberof Popper
- * @param config {Object} configuration
- * @returns {HTMLElement} popper
- */
- Popper.prototype.parse = function (config) {
- var defaultConfig = {
- tagName: 'div',
- classNames: ['popper'],
- attributes: [],
- parent: root.document.body,
- content: '',
- contentType: 'text',
- arrowTagName: 'div',
- arrowClassNames: ['popper__arrow'],
- arrowAttributes: ['x-arrow']
- };
- config = Object.assign({}, defaultConfig, config);
+ module.exports = __webpack_require__(13);
- var d = root.document;
+/***/ },
- var popper = d.createElement(config.tagName);
- addClassNames(popper, config.classNames);
- addAttributes(popper, config.attributes);
- if (config.contentType === 'node') {
- popper.appendChild(config.content.jquery ? config.content[0] : config.content);
- } else if (config.contentType === 'html') {
- popper.innerHTML = config.content;
- } else {
- popper.textContent = config.content;
- }
+/***/ 14:
+/***/ function(module, exports) {
- if (config.arrowTagName) {
- var arrow = d.createElement(config.arrowTagName);
- addClassNames(arrow, config.arrowClassNames);
- addAttributes(arrow, config.arrowAttributes);
- popper.appendChild(arrow);
- }
+ module.exports = __webpack_require__(5);
- var parent = config.parent.jquery ? config.parent[0] : config.parent;
+/***/ },
- // if the given parent is a string, use it to match an element
- // if more than one element is matched, the first one will be used as parent
- // if no elements are matched, the script will throw an error
- if (typeof parent === 'string') {
- parent = d.querySelectorAll(config.parent);
- if (parent.length > 1) {
- console.warn('WARNING: the given `parent` query(' + config.parent + ') matched more than one element, the first one will be used');
- }
- if (parent.length === 0) {
- throw 'ERROR: the given `parent` doesn\'t exists!';
- }
- parent = parent[0];
- }
- // if the given parent is a DOM nodes list or an array of nodes with more than one element,
- // the first one will be used as parent
- if (parent.length > 1 && parent instanceof Element === false) {
- console.warn('WARNING: you have passed as parent a list of elements, the first one will be used');
- parent = parent[0];
- }
+/***/ 15:
+/***/ function(module, exports) {
- // append the generated popper to its parent
- parent.appendChild(popper);
+ module.exports = __webpack_require__(22);
- return popper;
+/***/ },
- /**
- * Adds class names to the given element
- * @function
- * @ignore
- * @param {HTMLElement} target
- * @param {Array} classes
- */
- function addClassNames(element, classNames) {
- classNames.forEach(function (className) {
- element.classList.add(className);
- });
- }
+/***/ 46:
+/***/ function(module, exports) {
- /**
- * Adds attributes to the given element
- * @function
- * @ignore
- * @param {HTMLElement} target
- * @param {Array} attributes
- * @example
- * addAttributes(element, [ 'data-info:foobar' ]);
- */
- function addAttributes(element, attributes) {
- attributes.forEach(function (attribute) {
- element.setAttribute(attribute.split(':')[0], attribute.split(':')[1] || '');
- });
- }
- };
+ module.exports = __webpack_require__(15);
- /**
- * Helper used to get the position which will be applied to the popper
- * @method
- * @memberof Popper
- * @param config {HTMLElement} popper element
- * @param reference {HTMLElement} reference element
- * @returns {String} position
- */
- Popper.prototype._getPosition = function (popper, reference) {
- var container = getOffsetParent(reference);
+/***/ },
- if (this._options.forceAbsolute) {
- return 'absolute';
- }
+/***/ 60:
+/***/ function(module, exports) {
- // Decide if the popper will be fixed
- // If the reference element is inside a fixed context, the popper will be fixed as well to allow them to scroll together
- var isParentFixed = isFixed(reference, container);
- return isParentFixed ? 'fixed' : 'absolute';
- };
+ module.exports = __webpack_require__(23);
- /**
- * Get offsets to the popper
- * @method
- * @memberof Popper
- * @access private
- * @param {Element} popper - the popper element
- * @param {Element} reference - the reference element (the popper will be relative to this)
- * @returns {Object} An object containing the offsets which will be applied to the popper
- */
- Popper.prototype._getOffsets = function (popper, reference, placement) {
- placement = placement.split('-')[0];
- var popperOffsets = {};
+/***/ },
- popperOffsets.position = this.state.position;
- var isParentFixed = popperOffsets.position === 'fixed';
+/***/ 61:
+/***/ function(module, exports) {
- //
- // Get reference element position
- //
- var referenceOffsets = getOffsetRectRelativeToCustomParent(reference, getOffsetParent(popper), isParentFixed);
+ module.exports = __webpack_require__(24);
- //
- // Get popper sizes
- //
- var popperRect = getOuterSizes(popper);
+/***/ },
- //
- // Compute offsets of popper
- //
+/***/ 62:
+/***/ function(module, exports) {
- // depending by the popper placement we have to compute its offsets slightly differently
- if (['right', 'left'].indexOf(placement) !== -1) {
- popperOffsets.top = referenceOffsets.top + referenceOffsets.height / 2 - popperRect.height / 2;
- if (placement === 'left') {
- popperOffsets.left = referenceOffsets.left - popperRect.width;
- } else {
- popperOffsets.left = referenceOffsets.right;
- }
- } else {
- popperOffsets.left = referenceOffsets.left + referenceOffsets.width / 2 - popperRect.width / 2;
- if (placement === 'top') {
- popperOffsets.top = referenceOffsets.top - popperRect.height;
- } else {
- popperOffsets.top = referenceOffsets.bottom;
- }
- }
+ module.exports = __webpack_require__(16);
- // Add width and height to our offsets object
- popperOffsets.width = popperRect.width;
- popperOffsets.height = popperRect.height;
+/***/ },
- return {
- popper: popperOffsets,
- reference: referenceOffsets
- };
- };
+/***/ 63:
+/***/ function(module, exports) {
- /**
- * Setup needed event listeners used to update the popper position
- * @method
- * @memberof Popper
- * @access private
- */
- Popper.prototype._setupEventListeners = function () {
- // NOTE: 1 DOM access here
- this.state.updateBound = this.update.bind(this);
- root.addEventListener('resize', this.state.updateBound);
- // if the boundariesElement is window we don't need to listen for the scroll event
- if (this._options.boundariesElement !== 'window') {
- var target = getScrollParent(this._reference);
- // here it could be both `body` or `documentElement` thanks to Firefox, we then check both
- if (target === root.document.body || target === root.document.documentElement) {
- target = root;
- }
- target.addEventListener('scroll', this.state.updateBound);
- }
- };
+ module.exports = __webpack_require__(9);
- /**
- * Remove event listeners used to update the popper position
- * @method
- * @memberof Popper
- * @access private
- */
- Popper.prototype._removeEventListeners = function () {
- // NOTE: 1 DOM access here
- root.removeEventListener('resize', this.state.updateBound);
- if (this._options.boundariesElement !== 'window') {
- var target = getScrollParent(this._reference);
- // here it could be both `body` or `documentElement` thanks to Firefox, we then check both
- if (target === root.document.body || target === root.document.documentElement) {
- target = root;
- }
- target.removeEventListener('scroll', this.state.updateBound);
- }
- this.state.updateBound = null;
- };
+/***/ },
- /**
- * Computed the boundaries limits and return them
- * @method
- * @memberof Popper
- * @access private
- * @param {Object} data - Object containing the property "offsets" generated by `_getOffsets`
- * @param {Number} padding - Boundaries padding
- * @param {Element} boundariesElement - Element used to define the boundaries
- * @returns {Object} Coordinates of the boundaries
- */
- Popper.prototype._getBoundaries = function (data, padding, boundariesElement) {
- // NOTE: 1 DOM access here
- var boundaries = {};
- var width, height;
- if (boundariesElement === 'window') {
- var body = root.document.body,
- html = root.document.documentElement;
+/***/ 123:
+/***/ function(module, exports) {
- height = Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight);
- width = Math.max(body.scrollWidth, body.offsetWidth, html.clientWidth, html.scrollWidth, html.offsetWidth);
+ module.exports = __webpack_require__(4);
- boundaries = {
- top: 0,
- right: width,
- bottom: height,
- left: 0
- };
- } else if (boundariesElement === 'viewport') {
- var offsetParent = getOffsetParent(this._popper);
- var scrollParent = getScrollParent(this._popper);
- var offsetParentRect = getOffsetRect(offsetParent);
+/***/ },
- // Thanks the fucking native API, `document.body.scrollTop` & `document.documentElement.scrollTop`
- var getScrollTopValue = function getScrollTopValue(element) {
- return element == document.body ? Math.max(document.documentElement.scrollTop, document.body.scrollTop) : element.scrollTop;
- };
- var getScrollLeftValue = function getScrollLeftValue(element) {
- return element == document.body ? Math.max(document.documentElement.scrollLeft, document.body.scrollLeft) : element.scrollLeft;
- };
+/***/ 217:
+/***/ function(module, exports, __webpack_require__) {
- // if the popper is fixed we don't have to substract scrolling from the boundaries
- var scrollTop = data.offsets.popper.position === 'fixed' ? 0 : getScrollTopValue(scrollParent);
- var scrollLeft = data.offsets.popper.position === 'fixed' ? 0 : getScrollLeftValue(scrollParent);
+ var Component = __webpack_require__(3)(
+ /* script */
+ __webpack_require__(218),
+ /* template */
+ __webpack_require__(220),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- boundaries = {
- top: 0 - (offsetParentRect.top - scrollTop),
- right: root.document.documentElement.clientWidth - (offsetParentRect.left - scrollLeft),
- bottom: root.document.documentElement.clientHeight - (offsetParentRect.top - scrollTop),
- left: 0 - (offsetParentRect.left - scrollLeft)
- };
- } else {
- if (getOffsetParent(this._popper) === boundariesElement) {
- boundaries = {
- top: 0,
- left: 0,
- right: boundariesElement.clientWidth,
- bottom: boundariesElement.clientHeight
- };
- } else {
- boundaries = getOffsetRect(boundariesElement);
- }
- }
- boundaries.left += padding;
- boundaries.right -= padding;
- boundaries.top = boundaries.top + padding;
- boundaries.bottom = boundaries.bottom - padding;
- return boundaries;
- };
-
- /**
- * Loop trough the list of modifiers and run them in order, each of them will then edit the data object
- * @method
- * @memberof Popper
- * @access public
- * @param {Object} data
- * @param {Array} modifiers
- * @param {Function} ends
- */
- Popper.prototype.runModifiers = function (data, modifiers, ends) {
- var modifiersToRun = modifiers.slice();
- if (ends !== undefined) {
- modifiersToRun = this._options.modifiers.slice(0, getArrayKeyIndex(this._options.modifiers, ends));
- }
-
- modifiersToRun.forEach(function (modifier) {
- if (isFunction(modifier)) {
- data = modifier.call(this, data);
- }
- }.bind(this));
+ module.exports = Component.exports
- return data;
- };
- /**
- * Helper used to know if the given modifier depends from another one.
- * @method
- * @memberof Popper
- * @param {String} requesting - name of requesting modifier
- * @param {String} requested - name of requested modifier
- * @returns {Boolean}
- */
- Popper.prototype.isModifierRequired = function (requesting, requested) {
- var index = getArrayKeyIndex(this._options.modifiers, requesting);
- return !!this._options.modifiers.slice(0, index).filter(function (modifier) {
- return modifier === requested;
- }).length;
- };
+/***/ },
- //
- // Modifiers
- //
+/***/ 218:
+/***/ function(module, exports, __webpack_require__) {
- /**
- * Modifiers list
- * @namespace Popper.modifiers
- * @memberof Popper
- * @type {Object}
- */
- Popper.prototype.modifiers = {};
+ 'use strict';
- /**
- * Apply the computed styles to the popper element
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by `update` method
- * @returns {Object} The same data object
- */
- Popper.prototype.modifiers.applyStyle = function (data) {
- // apply the final offsets to the popper
- // NOTE: 1 DOM access here
- var styles = {
- position: data.offsets.popper.position
- };
+ exports.__esModule = true;
- // round top and left to avoid blurry text
- var left = Math.round(data.offsets.popper.left);
- var top = Math.round(data.offsets.popper.top);
+ 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; }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- // if gpuAcceleration is set to true and transform is supported, we use `translate3d` to apply the position to the popper
- // we automatically use the supported prefixed version if needed
- var prefixedProperty;
- if (this._options.gpuAcceleration && (prefixedProperty = getSupportedPropertyName('transform'))) {
- styles[prefixedProperty] = 'translate3d(' + left + 'px, ' + top + 'px, 0)';
- styles.top = 0;
- styles.left = 0;
- }
- // othwerise, we use the standard `left` and `top` properties
- else {
- styles.left = left;
- styles.top = top;
- }
+ var _emitter = __webpack_require__(14);
- // any property present in `data.styles` will be applied to the popper,
- // in this way we can make the 3rd party modifiers add custom styles to it
- // Be aware, modifiers could override the properties defined in the previous
- // lines of this modifier!
- Object.assign(styles, data.styles);
+ var _emitter2 = _interopRequireDefault(_emitter);
- setStyle(this._popper, styles);
+ var _util = __webpack_require__(219);
- // set an attribute which will be useful to style the tooltip (use it to properly position its arrow)
- // NOTE: 1 DOM access here
- this._popper.setAttribute('x-placement', data.placement);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- // if the arrow modifier is required and the arrow style has been computed, apply the arrow style
- if (this.isModifierRequired(this.modifiers.applyStyle, this.modifiers.arrow) && data.offsets.arrow) {
- setStyle(data.arrowElement, data.offsets.arrow);
- }
+ exports.default = {
+ mixins: [_emitter2.default],
- return data;
- };
+ name: 'ElOption',
- /**
- * Modifier used to shift the popper on the start or end of its reference element side
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by `update` method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.shift = function (data) {
- var placement = data.placement;
- var basePlacement = placement.split('-')[0];
- var shiftVariation = placement.split('-')[1];
+ componentName: 'ElOption',
- // if shift shiftVariation is specified, run the modifier
- if (shiftVariation) {
- var reference = data.offsets.reference;
- var popper = getPopperClientRect(data.offsets.popper);
+ props: {
+ value: {
+ required: true
+ },
+ label: [String, Number],
+ created: Boolean,
+ disabled: {
+ type: Boolean,
+ default: false
+ }
+ },
- var shiftOffsets = {
- y: {
- start: { top: reference.top },
- end: { top: reference.top + reference.height - popper.height }
- },
- x: {
- start: { left: reference.left },
- end: { left: reference.left + reference.width - popper.width }
- }
- };
+ data: function data() {
+ return {
+ index: -1,
+ groupDisabled: false,
+ visible: true,
+ hitState: false
+ };
+ },
- var axis = ['bottom', 'top'].indexOf(basePlacement) !== -1 ? 'x' : 'y';
- data.offsets.popper = Object.assign(popper, shiftOffsets[axis][shiftVariation]);
- }
+ 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 || '';
+ },
+ parent: function parent() {
+ var result = this.$parent;
+ while (!result.isSelect) {
+ result = result.$parent;
+ }
+ return result;
+ },
+ itemSelected: function itemSelected() {
+ if (!this.parent.multiple) {
+ return this.isEqual(this.value, this.parent.value);
+ } else {
+ return this.contains(this.parent.value, this.value);
+ }
+ },
+ limitReached: function limitReached() {
+ if (this.parent.multiple) {
+ return !this.itemSelected && this.parent.value.length >= this.parent.multipleLimit && this.parent.multipleLimit > 0;
+ } else {
+ return false;
+ }
+ }
+ },
- return data;
- };
+ watch: {
+ currentLabel: function currentLabel() {
+ if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
+ },
+ value: function value() {
+ if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
+ }
+ },
- /**
- * Modifier used to make sure the popper does not overflows from it's boundaries
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by `update` method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.preventOverflow = function (data) {
- var order = this._options.preventOverflowOrder;
- var popper = getPopperClientRect(data.offsets.popper);
+ methods: {
+ isEqual: function isEqual(a, b) {
+ if (!this.isObject) {
+ return a === b;
+ } else {
+ var valueKey = this.parent.valueKey;
+ return (0, _util.getValueByPath)(a, valueKey) === (0, _util.getValueByPath)(b, valueKey);
+ }
+ },
+ contains: function contains() {
+ var _this = this;
- var check = {
- left: function left() {
- var left = popper.left;
- if (popper.left < data.boundaries.left) {
- left = Math.max(popper.left, data.boundaries.left);
- }
- return { left: left };
- },
- right: function right() {
- var left = popper.left;
- if (popper.right > data.boundaries.right) {
- left = Math.min(popper.left, data.boundaries.right - popper.width);
- }
- return { left: left };
- },
- top: function top() {
- var top = popper.top;
- if (popper.top < data.boundaries.top) {
- top = Math.max(popper.top, data.boundaries.top);
- }
- return { top: top };
- },
- bottom: function bottom() {
- var top = popper.top;
- if (popper.bottom > data.boundaries.bottom) {
- top = Math.min(popper.top, data.boundaries.bottom - popper.height);
- }
- return { top: top };
- }
- };
+ var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
+ var target = arguments[1];
- order.forEach(function (direction) {
- data.offsets.popper = Object.assign(popper, check[direction]());
- });
+ if (!this.isObject) {
+ return arr.indexOf(target) > -1;
+ } else {
+ var _ret = function () {
+ var valueKey = _this.parent.valueKey;
+ return {
+ v: arr.some(function (item) {
+ return (0, _util.getValueByPath)(item, valueKey) === (0, _util.getValueByPath)(target, valueKey);
+ })
+ };
+ }();
- return data;
- };
+ if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
+ }
+ },
+ handleGroupDisabled: function handleGroupDisabled(val) {
+ this.groupDisabled = val;
+ },
+ hoverItem: function hoverItem() {
+ if (!this.disabled && !this.groupDisabled) {
+ this.parent.hoverIndex = this.parent.options.indexOf(this);
+ }
+ },
+ selectOptionClick: function selectOptionClick() {
+ if (this.disabled !== true && this.groupDisabled !== true) {
+ this.dispatch('ElSelect', 'handleOptionClick', this);
+ }
+ },
+ queryChange: function queryChange(query) {
+ // query 里如果有正则中的特殊字符,需要先将这些字符转义
+ var parsedQuery = String(query).replace(/(\^|\(|\)|\[|\]|\$|\*|\+|\.|\?|\\|\{|\}|\|)/g, '\\$1');
+ this.visible = new RegExp(parsedQuery, 'i').test(this.currentLabel) || this.created;
+ if (!this.visible) {
+ this.parent.filteredOptionsCount--;
+ }
+ },
+ resetIndex: function resetIndex() {
+ var _this2 = this;
- /**
- * Modifier used to make sure the popper is always near its reference
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by _update method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.keepTogether = function (data) {
- var popper = getPopperClientRect(data.offsets.popper);
- var reference = data.offsets.reference;
- var f = Math.floor;
+ this.$nextTick(function () {
+ _this2.index = _this2.parent.options.indexOf(_this2);
+ });
+ }
+ },
- if (popper.right < f(reference.left)) {
- data.offsets.popper.left = f(reference.left) - popper.width;
- }
- if (popper.left > f(reference.right)) {
- data.offsets.popper.left = f(reference.right);
- }
- if (popper.bottom < f(reference.top)) {
- data.offsets.popper.top = f(reference.top) - popper.height;
- }
- if (popper.top > f(reference.bottom)) {
- data.offsets.popper.top = f(reference.bottom);
- }
+ created: function created() {
+ this.parent.options.push(this);
+ this.parent.cachedOptions.push(this);
+ this.parent.optionsCount++;
+ this.parent.filteredOptionsCount++;
+ this.index = this.parent.options.indexOf(this);
- return data;
- };
+ this.$on('queryChange', this.queryChange);
+ this.$on('handleGroupDisabled', this.handleGroupDisabled);
+ this.$on('resetIndex', this.resetIndex);
+ },
+ beforeDestroy: function beforeDestroy() {
+ this.dispatch('ElSelect', 'onOptionDestroy', this);
+ }
+ };
- /**
- * Modifier used to flip the placement of the popper when the latter is starting overlapping its reference element.
- * Requires the `preventOverflow` modifier before it in order to work.
- * **NOTE:** This modifier will run all its previous modifiers everytime it tries to flip the popper!
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by _update method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.flip = function (data) {
- // check if preventOverflow is in the list of modifiers before the flip modifier.
- // otherwise flip would not work as expected.
- if (!this.isModifierRequired(this.modifiers.flip, this.modifiers.preventOverflow)) {
- console.warn('WARNING: preventOverflow modifier is required by flip modifier in order to work, be sure to include it before flip!');
- return data;
- }
+/***/ },
- if (data.flipped && data.placement === data._originalPlacement) {
- // seems like flip is trying to loop, probably there's not enough space on any of the flippable sides
- return data;
- }
+/***/ 219:
+/***/ function(module, exports) {
- var placement = data.placement.split('-')[0];
- var placementOpposite = getOppositePlacement(placement);
- var variation = data.placement.split('-')[1] || '';
+ module.exports = __webpack_require__(6);
- var flipOrder = [];
- if (this._options.flipBehavior === 'flip') {
- flipOrder = [placement, placementOpposite];
- } else {
- flipOrder = this._options.flipBehavior;
- }
+/***/ },
- flipOrder.forEach(function (step, index) {
- if (placement !== step || flipOrder.length === index + 1) {
- return;
- }
+/***/ 220:
+/***/ function(module, exports) {
- placement = data.placement.split('-')[0];
- placementOpposite = getOppositePlacement(placement);
+ module.exports={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.parent.hoverIndex === _vm.index
+ },
+ on: {
+ "mouseenter": _vm.hoverItem,
+ "click": function($event) {
+ $event.stopPropagation();
+ _vm.selectOptionClick($event)
+ }
+ }
+ }, [_vm._t("default", [_c('span', [_vm._v(_vm._s(_vm.currentLabel))])])], 2)
+ },staticRenderFns: []}
- var popperOffsets = getPopperClientRect(data.offsets.popper);
+/***/ },
- // this boolean is used to distinguish right and bottom from top and left
- // they need different computations to get flipped
- var a = ['right', 'bottom'].indexOf(placement) !== -1;
+/***/ 264:
+/***/ function(module, exports, __webpack_require__) {
- // using Math.floor because the reference offsets may contain decimals we are not going to consider here
- if (a && Math.floor(data.offsets.reference[placement]) > Math.floor(popperOffsets[placementOpposite]) || !a && Math.floor(data.offsets.reference[placement]) < Math.floor(popperOffsets[placementOpposite])) {
- // we'll use this boolean to detect any flip loop
- data.flipped = true;
- data.placement = flipOrder[index + 1];
- if (variation) {
- data.placement += '-' + variation;
- }
- data.offsets.popper = this._getOffsets(this._popper, this._reference, data.placement).popper;
+ 'use strict';
- data = this.runModifiers(data, this._options.modifiers, this._flip);
- }
- }.bind(this));
- return data;
- };
+ exports.__esModule = true;
- /**
- * Modifier used to add an offset to the popper, useful if you more granularity positioning your popper.
- * The offsets will shift the popper on the side of its reference element.
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by _update method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.offset = function (data) {
- var offset = this._options.offset;
- var popper = data.offsets.popper;
+ var _select = __webpack_require__(265);
- if (data.placement.indexOf('left') !== -1) {
- popper.top -= offset;
- } else if (data.placement.indexOf('right') !== -1) {
- popper.top += offset;
- } else if (data.placement.indexOf('top') !== -1) {
- popper.left -= offset;
- } else if (data.placement.indexOf('bottom') !== -1) {
- popper.left += offset;
- }
- return data;
- };
+ var _select2 = _interopRequireDefault(_select);
- /**
- * Modifier used to move the arrows on the edge of the popper to make sure them are always between the popper and the reference element
- * It will use the CSS outer size of the arrow element to know how many pixels of conjuction are needed
- * @method
- * @memberof Popper.modifiers
- * @argument {Object} data - The data object generated by _update method
- * @returns {Object} The data object, properly modified
- */
- Popper.prototype.modifiers.arrow = function (data) {
- var arrow = this._options.arrowElement;
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- // if the arrowElement is a string, suppose it's a CSS selector
- if (typeof arrow === 'string') {
- arrow = this._popper.querySelector(arrow);
- }
+ /* istanbul ignore next */
+ _select2.default.install = function (Vue) {
+ Vue.component(_select2.default.name, _select2.default);
+ };
- // if arrow element is not found, don't run the modifier
- if (!arrow) {
- return data;
- }
+ exports.default = _select2.default;
- // the arrow element must be child of its popper
- if (!this._popper.contains(arrow)) {
- console.warn('WARNING: `arrowElement` must be child of its popper element!');
- return data;
- }
+/***/ },
- // arrow depends on keepTogether in order to work
- if (!this.isModifierRequired(this.modifiers.arrow, this.modifiers.keepTogether)) {
- console.warn('WARNING: keepTogether modifier is required by arrow modifier in order to work, be sure to include it before arrow!');
- return data;
- }
+/***/ 265:
+/***/ function(module, exports, __webpack_require__) {
- var arrowStyle = {};
- var placement = data.placement.split('-')[0];
- var popper = getPopperClientRect(data.offsets.popper);
- var reference = data.offsets.reference;
- var isVertical = ['left', 'right'].indexOf(placement) !== -1;
+ var Component = __webpack_require__(3)(
+ /* script */
+ __webpack_require__(266),
+ /* template */
+ __webpack_require__(271),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- var len = isVertical ? 'height' : 'width';
- var side = isVertical ? 'top' : 'left';
- var altSide = isVertical ? 'left' : 'top';
- var opSide = isVertical ? 'bottom' : 'right';
- var arrowSize = getOuterSizes(arrow)[len];
+ module.exports = Component.exports
- //
- // extends keepTogether behavior making sure the popper and its reference have enough pixels in conjuction
- //
- // top/left side
- if (reference[opSide] - arrowSize < popper[side]) {
- data.offsets.popper[side] -= popper[side] - (reference[opSide] - arrowSize);
- }
- // bottom/right side
- if (reference[side] + arrowSize > popper[opSide]) {
- data.offsets.popper[side] += reference[side] + arrowSize - popper[opSide];
- }
+/***/ },
- // compute center of the popper
- var center = reference[side] + reference[len] / 2 - arrowSize / 2;
+/***/ 266:
+/***/ function(module, exports, __webpack_require__) {
- var sideValue = center - popper[side];
+ 'use strict';
- // prevent arrow from being placed not contiguously to its popper
- sideValue = Math.max(Math.min(popper[len] - arrowSize - 3, sideValue), 3);
- arrowStyle[side] = sideValue;
- arrowStyle[altSide] = ''; // make sure to remove any old style from the arrow
+ exports.__esModule = true;
- data.offsets.arrow = arrowStyle;
- data.arrowElement = arrow;
+ 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; }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- return data;
- };
+ var _emitter = __webpack_require__(14);
- //
- // Helpers
- //
+ var _emitter2 = _interopRequireDefault(_emitter);
- /**
- * Get the outer sizes of the given element (offset size + margins)
- * @function
- * @ignore
- * @argument {Element} element
- * @returns {Object} object containing width and height properties
- */
- function getOuterSizes(element) {
- // NOTE: 1 DOM access here
- var _display = element.style.display,
- _visibility = element.style.visibility;
- element.style.display = 'block';element.style.visibility = 'hidden';
- var calcWidthToForceRepaint = element.offsetWidth;
+ var _locale = __webpack_require__(61);
- // original method
- var styles = root.getComputedStyle(element);
- var x = parseFloat(styles.marginTop) + parseFloat(styles.marginBottom);
- var y = parseFloat(styles.marginLeft) + parseFloat(styles.marginRight);
- var result = { width: element.offsetWidth + y, height: element.offsetHeight + x };
+ var _locale2 = _interopRequireDefault(_locale);
- // reset element styles
- element.style.display = _display;element.style.visibility = _visibility;
- return result;
- }
+ var _input = __webpack_require__(9);
- /**
- * Get the opposite placement of the given one/
- * @function
- * @ignore
- * @argument {String} placement
- * @returns {String} flipped placement
- */
- function getOppositePlacement(placement) {
- var hash = { left: 'right', right: 'left', bottom: 'top', top: 'bottom' };
- return placement.replace(/left|right|bottom|top/g, function (matched) {
- return hash[matched];
- });
- }
+ var _input2 = _interopRequireDefault(_input);
- /**
- * Given the popper offsets, generate an output similar to getBoundingClientRect
- * @function
- * @ignore
- * @argument {Object} popperOffsets
- * @returns {Object} ClientRect like output
- */
- function getPopperClientRect(popperOffsets) {
- var offsets = Object.assign({}, popperOffsets);
- offsets.right = offsets.left + offsets.width;
- offsets.bottom = offsets.top + offsets.height;
- return offsets;
- }
+ var _selectDropdown = __webpack_require__(267);
- /**
- * Given an array and the key to find, returns its index
- * @function
- * @ignore
- * @argument {Array} arr
- * @argument keyToFind
- * @returns index or null
- */
- function getArrayKeyIndex(arr, keyToFind) {
- var i = 0,
- key;
- for (key in arr) {
- if (arr[key] === keyToFind) {
- return i;
- }
- i++;
- }
- return null;
- }
+ var _selectDropdown2 = _interopRequireDefault(_selectDropdown);
- /**
- * Get CSS computed property of the given element
- * @function
- * @ignore
- * @argument {Eement} element
- * @argument {String} property
- */
- function getStyleComputedProperty(element, property) {
- // NOTE: 1 DOM access here
- var css = root.getComputedStyle(element, null);
- return css[property];
- }
+ var _option = __webpack_require__(217);
- /**
- * Returns the offset parent of the given element
- * @function
- * @ignore
- * @argument {Element} element
- * @returns {Element} offset parent
- */
- function getOffsetParent(element) {
- // NOTE: 1 DOM access here
- var offsetParent = element.offsetParent;
- return offsetParent === root.document.body || !offsetParent ? root.document.documentElement : offsetParent;
- }
+ var _option2 = _interopRequireDefault(_option);
- /**
- * Returns the scrolling parent of the given element
- * @function
- * @ignore
- * @argument {Element} element
- * @returns {Element} offset parent
- */
- function getScrollParent(element) {
- var parent = element.parentNode;
+ var _tag = __webpack_require__(270);
- if (!parent) {
- return element;
- }
+ var _tag2 = _interopRequireDefault(_tag);
- if (parent === root.document) {
- // Firefox puts the scrollTOp value on `documentElement` instead of `body`, we then check which of them is
- // greater than 0 and return the proper element
- if (root.document.body.scrollTop) {
- return root.document.body;
- } else {
- return root.document.documentElement;
- }
- }
+ var _scrollbar = __webpack_require__(15);
- // Firefox want us to check `-x` and `-y` variations as well
- if (['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow')) !== -1 || ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-x')) !== -1 || ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-y')) !== -1) {
- // If the detected scrollParent is body, we perform an additional check on its parentNode
- // in this way we'll get body if the browser is Chrome-ish, or documentElement otherwise
- // fixes issue #65
- return parent;
- }
- return getScrollParent(element.parentNode);
- }
+ var _scrollbar2 = _interopRequireDefault(_scrollbar);
- /**
- * Check if the given element is fixed or is inside a fixed parent
- * @function
- * @ignore
- * @argument {Element} element
- * @argument {Element} customContainer
- * @returns {Boolean} answer to "isFixed?"
- */
- function isFixed(element) {
- if (element === root.document.body) {
- return false;
- }
- if (getStyleComputedProperty(element, 'position') === 'fixed') {
- return true;
- }
- return element.parentNode ? isFixed(element.parentNode) : element;
- }
+ var _debounce = __webpack_require__(63);
- /**
- * Set the style to the given popper
- * @function
- * @ignore
- * @argument {Element} element - Element to apply the style to
- * @argument {Object} styles - Object with a list of properties and values which will be applied to the element
- */
- function setStyle(element, styles) {
- function is_numeric(n) {
- return n !== '' && !isNaN(parseFloat(n)) && isFinite(n);
- }
- Object.keys(styles).forEach(function (prop) {
- var unit = '';
- // add unit if the value is numeric and is one of the following
- if (['width', 'height', 'top', 'right', 'bottom', 'left'].indexOf(prop) !== -1 && is_numeric(styles[prop])) {
- unit = 'px';
- }
- element.style[prop] = styles[prop] + unit;
- });
- }
+ var _debounce2 = _interopRequireDefault(_debounce);
- /**
- * Check if the given variable is a function
- * @function
- * @ignore
- * @argument {*} functionToCheck - variable to check
- * @returns {Boolean} answer to: is a function?
- */
- function isFunction(functionToCheck) {
- var getType = {};
- return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
- }
+ var _clickoutside = __webpack_require__(10);
- /**
- * Get the position of the given element, relative to its offset parent
- * @function
- * @ignore
- * @param {Element} element
- * @return {Object} position - Coordinates of the element and its `scrollTop`
- */
- function getOffsetRect(element) {
- var elementRect = {
- width: element.offsetWidth,
- height: element.offsetHeight,
- left: element.offsetLeft,
- top: element.offsetTop
- };
+ var _clickoutside2 = _interopRequireDefault(_clickoutside);
- elementRect.right = elementRect.left + elementRect.width;
- elementRect.bottom = elementRect.top + elementRect.height;
+ var _dom = __webpack_require__(123);
- // position
- return elementRect;
- }
+ var _resizeEvent = __webpack_require__(46);
- /**
- * Get bounding client rect of given element
- * @function
- * @ignore
- * @param {HTMLElement} element
- * @return {Object} client rect
- */
- function getBoundingClientRect(element) {
- var rect = element.getBoundingClientRect();
+ var _locale3 = __webpack_require__(62);
- // whether the IE version is lower than 11
- var isIE = navigator.userAgent.indexOf("MSIE") != -1;
+ var _scrollIntoView = __webpack_require__(60);
- // fix ie document bounding top always 0 bug
- var rectTop = isIE && element.tagName === 'HTML' ? -element.scrollTop : rect.top;
+ var _scrollIntoView2 = _interopRequireDefault(_scrollIntoView);
- return {
- left: rect.left,
- top: rectTop,
- right: rect.right,
- bottom: rect.bottom,
- width: rect.right - rect.left,
- height: rect.bottom - rectTop
- };
- }
+ var _util = __webpack_require__(219);
- /**
- * Given an element and one of its parents, return the offset
- * @function
- * @ignore
- * @param {HTMLElement} element
- * @param {HTMLElement} parent
- * @return {Object} rect
- */
- function getOffsetRectRelativeToCustomParent(element, parent, fixed) {
- var elementRect = getBoundingClientRect(element);
- var parentRect = getBoundingClientRect(parent);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- if (fixed) {
- var scrollParent = getScrollParent(parent);
- parentRect.top += scrollParent.scrollTop;
- parentRect.bottom += scrollParent.scrollTop;
- parentRect.left += scrollParent.scrollLeft;
- parentRect.right += scrollParent.scrollLeft;
- }
+ var sizeMap = {
+ 'large': 42,
+ 'small': 30,
+ 'mini': 22
+ };
- var rect = {
- top: elementRect.top - parentRect.top,
- left: elementRect.left - parentRect.left,
- bottom: elementRect.top - parentRect.top + elementRect.height,
- right: elementRect.left - parentRect.left + elementRect.width,
- width: elementRect.width,
- height: elementRect.height
- };
- return rect;
- }
+ exports.default = {
+ mixins: [_emitter2.default, _locale2.default],
- /**
- * Get the prefixed supported property name
- * @function
- * @ignore
- * @argument {String} property (camelCase)
- * @returns {String} prefixed property (camelCase)
- */
- function getSupportedPropertyName(property) {
- var prefixes = ['', 'ms', 'webkit', 'moz', 'o'];
+ name: 'ElSelect',
- for (var i = 0; i < prefixes.length; i++) {
- var toCheck = prefixes[i] ? prefixes[i] + property.charAt(0).toUpperCase() + property.slice(1) : property;
- if (typeof root.document.body.style[toCheck] !== 'undefined') {
- return toCheck;
- }
- }
- return null;
- }
+ componentName: 'ElSelect',
- /**
- * The Object.assign() method is used to copy the values of all enumerable own properties from one or more source
- * objects to a target object. It will return the target object.
- * This polyfill doesn't support symbol properties, since ES5 doesn't have symbols anyway
- * Source: https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign
- * @function
- * @ignore
- */
- if (!Object.assign) {
- Object.defineProperty(Object, 'assign', {
- enumerable: false,
- configurable: true,
- writable: true,
- value: function value(target) {
- if (target === undefined || target === null) {
- throw new TypeError('Cannot convert first argument to object');
- }
+ computed: {
+ iconClass: function iconClass() {
+ var criteria = this.clearable && !this.disabled && this.inputHovering && !this.multiple && this.value !== undefined && this.value !== '';
+ return criteria ? 'circle-close is-show-close' : this.remote && this.filterable ? '' : 'caret-top';
+ },
+ 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.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 to = Object(target);
- for (var i = 1; i < arguments.length; i++) {
- var nextSource = arguments[i];
- if (nextSource === undefined || nextSource === null) {
- continue;
- }
- nextSource = Object(nextSource);
+ 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;
+ }
+ },
- var keysArray = Object.keys(nextSource);
- for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex++) {
- var nextKey = keysArray[nextIndex];
- var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);
- if (desc !== undefined && desc.enumerable) {
- to[nextKey] = nextSource[nextKey];
- }
- }
- }
- return to;
- }
- });
- }
+ components: {
+ ElInput: _input2.default,
+ ElSelectMenu: _selectDropdown2.default,
+ ElOption: _option2.default,
+ ElTag: _tag2.default,
+ ElScrollbar: _scrollbar2.default
+ },
- return Popper;
-});
-
-/***/ }),
-/* 44 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-exports.__esModule = true;
-exports.default = {
- el: {
- colorpicker: {
- confirm: '确定',
- clear: '清空'
- },
- datepicker: {
- now: '此刻',
- today: '今天',
- cancel: '取消',
- clear: '清空',
- confirm: '确定',
- selectDate: '选择日期',
- selectTime: '选择时间',
- startDate: '开始日期',
- startTime: '开始时间',
- endDate: '结束日期',
- endTime: '结束时间',
- year: '年',
- month1: '1 月',
- month2: '2 月',
- month3: '3 月',
- month4: '4 月',
- month5: '5 月',
- month6: '6 月',
- month7: '7 月',
- month8: '8 月',
- month9: '9 月',
- month10: '10 月',
- month11: '11 月',
- month12: '12 月',
- // week: '周次',
- weeks: {
- sun: '日',
- mon: '一',
- tue: '二',
- wed: '三',
- thu: '四',
- fri: '五',
- sat: '六'
- },
- months: {
- jan: '一月',
- feb: '二月',
- mar: '三月',
- apr: '四月',
- may: '五月',
- jun: '六月',
- jul: '七月',
- aug: '八月',
- sep: '九月',
- oct: '十月',
- nov: '十一月',
- dec: '十二月'
- }
- },
- select: {
- loading: '加载中',
- noMatch: '无匹配数据',
- noData: '无数据',
- placeholder: '请选择'
- },
- cascader: {
- noMatch: '无匹配数据',
- loading: '加载中',
- placeholder: '请选择'
- },
- pagination: {
- goto: '前往',
- pagesize: '条/页',
- total: '共 {total} 条',
- pageClassifier: '页'
- },
- messagebox: {
- title: '提示',
- confirm: '确定',
- cancel: '取消',
- error: '输入的数据不合法!'
- },
- upload: {
- delete: '删除',
- preview: '查看图片',
- continue: '继续上传'
- },
- table: {
- emptyText: '暂无数据',
- confirmFilter: '筛选',
- resetFilter: '重置',
- clearFilter: '全部',
- sumText: '合计'
- },
- tree: {
- emptyText: '暂无数据'
- },
- transfer: {
- noMatch: '无匹配数据',
- noData: '无数据',
- titles: ['列表 1', '列表 2'],
- filterPlaceholder: '请输入搜索内容',
- noCheckedFormat: '共 {total} 项',
- hasCheckedFormat: '已选 {checked}/{total} 项'
- }
- }
-};
-
-/***/ }),
-/* 45 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-var index$2 = function isMergeableObject(value) {
- return isNonNullObject(value) && isNotSpecial(value)
-};
-
-function isNonNullObject(value) {
- return !!value && typeof value === 'object'
-}
-
-function isNotSpecial(value) {
- var stringValue = Object.prototype.toString.call(value);
-
- return stringValue !== '[object RegExp]'
- && stringValue !== '[object Date]'
-}
-
-function emptyTarget(val) {
- return Array.isArray(val) ? [] : {}
-}
-
-function cloneIfNecessary(value, optionsArgument) {
- var clone = optionsArgument && optionsArgument.clone === true;
- return (clone && index$2(value)) ? deepmerge(emptyTarget(value), value, optionsArgument) : value
-}
-
-function defaultArrayMerge(target, source, optionsArgument) {
- var destination = target.slice();
- source.forEach(function(e, i) {
- if (typeof destination[i] === 'undefined') {
- destination[i] = cloneIfNecessary(e, optionsArgument);
- } else if (index$2(e)) {
- destination[i] = deepmerge(target[i], e, optionsArgument);
- } else if (target.indexOf(e) === -1) {
- destination.push(cloneIfNecessary(e, optionsArgument));
- }
- });
- return destination
-}
-
-function mergeObject(target, source, optionsArgument) {
- var destination = {};
- if (index$2(target)) {
- Object.keys(target).forEach(function(key) {
- destination[key] = cloneIfNecessary(target[key], optionsArgument);
- });
- }
- Object.keys(source).forEach(function(key) {
- if (!index$2(source[key]) || !target[key]) {
- destination[key] = cloneIfNecessary(source[key], optionsArgument);
- } else {
- destination[key] = deepmerge(target[key], source[key], optionsArgument);
- }
- });
- return destination
-}
-
-function deepmerge(target, source, optionsArgument) {
- var sourceIsArray = Array.isArray(source);
- var targetIsArray = Array.isArray(target);
- var options = optionsArgument || { arrayMerge: defaultArrayMerge };
- var sourceAndTargetTypesMatch = sourceIsArray === targetIsArray;
-
- if (!sourceAndTargetTypesMatch) {
- return cloneIfNecessary(source, optionsArgument)
- } else if (sourceIsArray) {
- var arrayMerge = options.arrayMerge || defaultArrayMerge;
- return arrayMerge(target, source, optionsArgument)
- } else {
- return mergeObject(target, source, optionsArgument)
- }
-}
-
-deepmerge.all = function deepmergeAll(array, optionsArgument) {
- if (!Array.isArray(array) || array.length < 2) {
- throw new Error('first argument should be an array with at least two elements')
- }
-
- // we are sure there are at least 2 values, so it is safe to have no initial value
- return array.reduce(function(prev, next) {
- return deepmerge(prev, next, optionsArgument)
- })
-};
-
-var index = deepmerge;
-
-module.exports = index;
-
-
-/***/ }),
-/* 46 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-exports.__esModule = true;
-
-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; };
-
-exports.default = function (Vue) {
-
- /**
- * template
- *
- * @param {String} string
- * @param {Array} ...args
- * @return {String}
- */
-
- function template(string) {
- for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
- args[_key - 1] = arguments[_key];
- }
-
- if (args.length === 1 && _typeof(args[0]) === 'object') {
- args = args[0];
- }
-
- if (!args || !args.hasOwnProperty) {
- args = {};
- }
-
- return string.replace(RE_NARGS, function (match, prefix, i, index) {
- var result = void 0;
-
- if (string[index - 1] === '{' && string[index + match.length] === '}') {
- return i;
- } else {
- result = (0, _util.hasOwn)(args, i) ? args[i] : null;
- if (result === null || result === undefined) {
- return '';
- }
-
- return result;
- }
- });
- }
-
- return template;
-};
-
-var _util = __webpack_require__(6);
-
-var RE_NARGS = /(%|)\{([0-9a-zA-Z_]+)\}/g;
-/**
- * String format template
- * - Inspired:
- * https://github.com/Matt-Esch/string-template/index.js
- */
-
-/***/ }),
-/* 47 */
-/***/ (function(module, exports, __webpack_require__) {
-
-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] = {
-/******/ exports: {},
-/******/ id: moduleId,
-/******/ loaded: false
-/******/ };
-
-/******/ // Execute the module function
-/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
-
-/******/ // Flag the module as loaded
-/******/ module.loaded = true;
-
-/******/ // Return the exports of the module
-/******/ return module.exports;
-/******/ }
+ directives: { Clickoutside: _clickoutside2.default },
+ props: {
+ name: String,
+ value: {
+ required: true
+ },
+ 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 (0, _locale3.t)('el.select.placeholder');
+ }
+ },
+ defaultFirstOption: Boolean,
+ valueKey: {
+ type: String,
+ default: 'value'
+ }
+ },
-/******/ // expose the modules object (__webpack_modules__)
-/******/ __webpack_require__.m = modules;
+ data: function data() {
+ return {
+ options: [],
+ cachedOptions: [],
+ createdLabel: null,
+ createdSelected: false,
+ selected: this.multiple ? [] : {},
+ isSelect: true,
+ inputLength: 20,
+ inputWidth: 0,
+ cachedPlaceHolder: '',
+ optionsCount: 0,
+ filteredOptionsCount: 0,
+ visible: false,
+ selectedLabel: '',
+ hoverIndex: -1,
+ query: '',
+ optionsAllDisabled: false,
+ inputHovering: false,
+ currentPlaceholder: ''
+ };
+ },
-/******/ // expose the module cache
-/******/ __webpack_require__.c = installedModules;
-/******/ // __webpack_public_path__
-/******/ __webpack_require__.p = "/dist/";
+ watch: {
+ placeholder: function placeholder(val) {
+ this.cachedPlaceHolder = this.currentPlaceholder = val;
+ },
+ value: function value(val) {
+ if (this.multiple) {
+ this.resetInputHeight();
+ if (val.length > 0 || this.$refs.input && this.query !== '') {
+ this.currentPlaceholder = '';
+ } else {
+ this.currentPlaceholder = this.cachedPlaceHolder;
+ }
+ }
+ this.setSelected();
+ if (this.filterable && !this.multiple) {
+ this.inputLength = 20;
+ }
+ this.$emit('change', val);
+ this.dispatch('ElFormItem', 'el.form.change', val);
+ },
+ query: function query(val) {
+ var _this2 = this;
-/******/ // Load entry module and return exports
-/******/ return __webpack_require__(0);
-/******/ })
-/************************************************************************/
-/******/ ({
+ this.$nextTick(function () {
+ if (_this2.visible) _this2.broadcast('ElSelectDropdown', 'updatePopper');
+ });
+ this.hoverIndex = -1;
+ if (this.multiple && this.filterable) {
+ this.inputLength = this.$refs.input.value.length * 15 + 20;
+ this.managePlaceholder();
+ this.resetInputHeight();
+ }
+ if (this.remote && typeof this.remoteMethod === 'function') {
+ this.hoverIndex = -1;
+ this.remoteMethod(val);
+ this.broadcast('ElOption', 'resetIndex');
+ } 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();
+ }
+ },
+ visible: function visible(val) {
+ var _this3 = this;
-/***/ 0:
-/***/ function(module, exports, __webpack_require__) {
+ if (!val) {
+ this.$refs.reference.$el.querySelector('input').blur();
+ this.handleIconHide();
+ this.broadcast('ElSelectDropdown', 'destroyPopper');
+ if (this.$refs.input) {
+ this.$refs.input.blur();
+ }
+ this.query = '';
+ this.selectedLabel = '';
+ this.inputLength = 20;
+ 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.createdOption) {
+ this.selectedLabel = this.createdLabel;
+ } else {
+ this.selectedLabel = this.selected.currentLabel;
+ }
+ if (this.filterable) this.query = this.selectedLabel;
+ }
+ }
+ } else {
+ this.handleIconShow();
+ this.broadcast('ElSelectDropdown', 'updatePopper');
+ if (this.filterable) {
+ this.query = this.selectedLabel;
+ if (this.multiple) {
+ this.$refs.input.focus();
+ } else {
+ if (!this.remote) {
+ this.broadcast('ElOption', 'queryChange', '');
+ this.broadcast('ElOptionGroup', 'queryChange');
+ }
+ this.broadcast('ElInput', 'inputSelect');
+ }
+ }
+ }
+ this.$emit('visible-change', val);
+ },
+ options: function options(val) {
+ if (this.$isServer) return;
+ this.optionsAllDisabled = val.length === val.filter(function (item) {
+ return item.disabled === true;
+ }).length;
+ 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();
+ }
+ }
+ },
- module.exports = __webpack_require__(216);
+ methods: {
+ handleIconHide: function handleIconHide() {
+ var icon = this.$el.querySelector('.el-input__icon');
+ if (icon) {
+ (0, _dom.removeClass)(icon, 'is-reverse');
+ }
+ },
+ handleIconShow: function handleIconShow() {
+ var icon = this.$el.querySelector('.el-input__icon');
+ if (icon && !(0, _dom.hasClass)(icon, 'el-icon-circle-close')) {
+ (0, _dom.addClass)(icon, 'is-reverse');
+ }
+ },
+ 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');
+ (0, _scrollIntoView2.default)(menu, target);
+ }
+ },
+ handleMenuEnter: function handleMenuEnter() {
+ var _this4 = this;
+ this.$nextTick(function () {
+ return _this4.scrollToOption(_this4.selected);
+ });
+ },
+ getOption: function getOption(value) {
+ var option = void 0;
+ var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
+ for (var i = this.cachedOptions.length - 1; i >= 0; i--) {
+ var cachedOption = this.cachedOptions[i];
+ var isEqual = isObject ? (0, _util.getValueByPath)(cachedOption.value, this.valueKey) === (0, _util.getValueByPath)(value, this.valueKey) : cachedOption.value === value;
+ if (isEqual) {
+ option = cachedOption;
+ break;
+ }
+ }
+ if (option) return option;
+ var label = !isObject ? value : '';
+ var newOption = {
+ value: value,
+ currentLabel: label
+ };
+ if (this.multiple) {
+ newOption.hitState = false;
+ }
+ return newOption;
+ },
+ setSelected: function setSelected() {
+ var _this5 = 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(_this5.getOption(value));
+ });
+ }
+ this.selected = result;
+ this.$nextTick(function () {
+ _this5.resetInputHeight();
+ });
+ },
+ handleFocus: function handleFocus() {
+ this.visible = true;
+ },
+ handleIconClick: function handleIconClick(event) {
+ if (this.iconClass.indexOf('circle-close') > -1) {
+ this.deleteSelected(event);
+ } else {
+ this.toggleMenu();
+ }
+ },
+ handleMouseDown: function handleMouseDown(event) {
+ if (event.target.tagName !== 'INPUT') return;
+ if (this.visible) {
+ this.handleClose();
+ event.preventDefault();
+ }
+ },
+ doDestroy: function doDestroy() {
+ this.$refs.popper && this.$refs.popper.doDestroy();
+ this.dropdownUl = null;
+ },
+ 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;
-/***/ 3:
-/***/ function(module, exports) {
+ if (hit === true || hit === false) {
+ option.hitState = hit;
+ return hit;
+ }
- /* globals __VUE_SSR_CONTEXT__ */
+ 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);
+ }
+ },
+ 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 _this6 = this;
- // this module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle
+ this.$nextTick(function () {
+ if (!_this6.$refs.reference) return;
+ var inputChildNodes = _this6.$refs.reference.$el.childNodes;
+ var input = [].filter.call(inputChildNodes, function (item) {
+ return item.tagName === 'INPUT';
+ })[0];
+ input.style.height = Math.max(_this6.$refs.tags.clientHeight + 6, sizeMap[_this6.size] || 36) + 'px';
+ if (_this6.visible && _this6.emptyText !== false) {
+ _this6.broadcast('ElSelectDropdown', 'updatePopper');
+ }
+ });
+ },
+ resetHoverIndex: function resetHoverIndex() {
+ var _this7 = this;
- module.exports = function normalizeComponent (
- rawScriptExports,
- compiledTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier /* server only */
- ) {
- var esModule
- var scriptExports = rawScriptExports = rawScriptExports || {}
+ setTimeout(function () {
+ if (!_this7.multiple) {
+ _this7.hoverIndex = _this7.options.indexOf(_this7.selected);
+ } else {
+ if (_this7.selected.length > 0) {
+ _this7.hoverIndex = Math.min.apply(null, _this7.selected.map(function (item) {
+ return _this7.options.indexOf(item);
+ }));
+ } else {
+ _this7.hoverIndex = -1;
+ }
+ }
+ }, 300);
+ },
+ handleOptionSelect: function handleOptionSelect(option) {
+ var _this8 = this;
- // ES6 modules interop
- var type = typeof rawScriptExports.default
- if (type === 'object' || type === 'function') {
- esModule = rawScriptExports
- scriptExports = rawScriptExports.default
- }
+ 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);
+ if (option.created) {
+ this.query = '';
+ this.inputLength = 20;
+ }
+ if (this.filterable) this.$refs.input.focus();
+ } else {
+ this.$emit('input', option.value);
+ this.visible = false;
+ }
+ this.$nextTick(function () {
+ return _this8.scrollToOption(option);
+ });
+ },
+ getValueIndex: function getValueIndex() {
+ var _this9 = this;
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
+ var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
+ var value = arguments[1];
- // render functions
- if (compiledTemplate) {
- options.render = compiledTemplate.render
- options.staticRenderFns = compiledTemplate.staticRenderFns
- }
+ var isObject = Object.prototype.toString.call(value).toLowerCase() === '[object object]';
+ if (!isObject) {
+ return arr.indexOf(value);
+ } else {
+ var _ret = function () {
+ var valueKey = _this9.valueKey;
+ var index = -1;
+ arr.some(function (item, i) {
+ if ((0, _util.getValueByPath)(item, valueKey) === (0, _util.getValueByPath)(value, valueKey)) {
+ index = i;
+ return true;
+ }
+ return false;
+ });
+ return {
+ v: index
+ };
+ }();
- // scopedId
- if (scopeId) {
- options._scopeId = scopeId
- }
+ if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
+ }
+ },
+ toggleMenu: function toggleMenu() {
+ if (this.filterable && this.query === '' && this.visible) {
+ return;
+ }
+ if (!this.disabled) {
+ this.visible = !this.visible;
+ }
+ },
+ navigateOptions: function navigateOptions(direction) {
+ var _this10 = this;
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context = context || (this.$vnode && this.$vnode.ssrContext)
- // 2.2 with runInNewContext: true
- if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
- context = __VUE_SSR_CONTEXT__
+ if (!this.visible) {
+ this.visible = true;
+ return;
}
- // inject component styles
- if (injectStyles) {
- injectStyles.call(this, context)
+ if (this.options.length === 0 || this.filteredOptionsCount === 0) return;
+ this.optionsAllDisabled = this.options.length === this.options.filter(function (item) {
+ return item.disabled === true;
+ }).length;
+ if (!this.optionsAllDisabled) {
+ if (direction === 'next') {
+ this.hoverIndex++;
+ if (this.hoverIndex === this.options.length) {
+ this.hoverIndex = 0;
+ }
+ if (this.options[this.hoverIndex].disabled === true || this.options[this.hoverIndex].groupDisabled === true || !this.options[this.hoverIndex].visible) {
+ this.navigateOptions('next');
+ }
+ }
+ if (direction === 'prev') {
+ this.hoverIndex--;
+ if (this.hoverIndex < 0) {
+ this.hoverIndex = this.options.length - 1;
+ }
+ if (this.options[this.hoverIndex].disabled === true || this.options[this.hoverIndex].groupDisabled === true || !this.options[this.hoverIndex].visible) {
+ this.navigateOptions('prev');
+ }
+ }
}
- // register component module identifier for async chunk inferrence
- if (context && context._registeredComponents) {
- context._registeredComponents.add(moduleIdentifier)
+ this.$nextTick(function () {
+ return _this10.scrollToOption(_this10.options[_this10.hoverIndex]);
+ });
+ },
+ selectOption: function selectOption() {
+ if (this.options[this.hoverIndex]) {
+ this.handleOptionSelect(this.options[this.hoverIndex]);
+ }
+ },
+ deleteSelected: function deleteSelected(event) {
+ event.stopPropagation();
+ this.$emit('input', '');
+ this.visible = false;
+ this.$emit('clear');
+ },
+ deleteTag: function deleteTag(event, tag) {
+ var index = this.selected.indexOf(tag);
+ if (index > -1 && !this.disabled) {
+ var value = this.value.slice();
+ value.splice(index, 1);
+ this.$emit('input', value);
+ this.$emit('remove-tag', tag);
+ }
+ event.stopPropagation();
+ },
+ onInputChange: function onInputChange() {
+ if (this.filterable) {
+ this.query = this.selectedLabel;
+ }
+ },
+ onOptionDestroy: function onOptionDestroy(option) {
+ this.optionsCount--;
+ this.filteredOptionsCount--;
+ var index = this.options.indexOf(option);
+ if (index > -1) {
+ this.options.splice(index, 1);
+ }
+ this.broadcast('ElOption', 'resetIndex');
+ },
+ 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;
+ for (var i = 0; i !== this.options.length; ++i) {
+ var option = this.options[i];
+ if (this.query) {
+ // pick first options that passes the filter
+ if (!option.disabled && !option.groupDisabled && option.visible) {
+ this.hoverIndex = i;
+ break;
+ }
+ } else {
+ // pick currently selected option
+ if (option.itemSelected) {
+ this.hoverIndex = i;
+ break;
+ }
+ }
+ }
+ },
+ getValueKey: function getValueKey(item) {
+ var type = _typeof(item.value);
+ if (type === 'number' || type === 'string') {
+ return item.value;
+ } else {
+ return (0, _util.getValueByPath)(item.value, this.valueKey);
}
}
- // used by ssr in case component is cached and beforeCreate
- // never gets called
- options._ssrRegister = hook
- } else if (injectStyles) {
- hook = injectStyles
- }
-
- if (hook) {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
-
- return {
- esModule: esModule,
- exports: scriptExports,
- options: options
- }
- }
-
-
-/***/ },
-
-/***/ 14:
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(5);
-
-/***/ },
-
-/***/ 216:
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
+ },
- exports.__esModule = true;
+ created: function created() {
+ var _this11 = this;
- var _option = __webpack_require__(217);
+ 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.setSelected();
- var _option2 = _interopRequireDefault(_option);
+ this.debouncedOnInputChange = (0, _debounce2.default)(this.debounce, function () {
+ _this11.onInputChange();
+ });
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ this.$on('handleOptionClick', this.handleOptionSelect);
+ this.$on('onOptionDestroy', this.onOptionDestroy);
+ this.$on('setSelected', this.setSelected);
+ },
+ mounted: function mounted() {
+ var _this12 = this;
- /* istanbul ignore next */
- _option2.default.install = function (Vue) {
- Vue.component(_option2.default.name, _option2.default);
+ if (this.multiple && Array.isArray(this.value) && this.value.length > 0) {
+ this.currentPlaceholder = '';
+ }
+ (0, _resizeEvent.addResizeListener)(this.$el, this.handleResize);
+ if (this.remote && this.multiple) {
+ this.resetInputHeight();
+ }
+ this.$nextTick(function () {
+ if (_this12.$refs.reference && _this12.$refs.reference.$el) {
+ _this12.inputWidth = _this12.$refs.reference.$el.getBoundingClientRect().width;
+ }
+ });
+ },
+ beforeDestroy: function beforeDestroy() {
+ if (this.$el && this.handleResize) (0, _resizeEvent.removeResizeListener)(this.$el, this.handleResize);
+ }
};
- exports.default = _option2.default;
-
/***/ },
-/***/ 217:
+/***/ 267:
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(3)(
/* script */
- __webpack_require__(218),
+ __webpack_require__(268),
/* template */
- __webpack_require__(220),
+ __webpack_require__(269),
/* styles */
null,
/* scopeId */
@@ -65333,220 +64524,308 @@ module.exports =
/***/ },
-/***/ 218:
+/***/ 268:
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- 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; }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
-
- var _emitter = __webpack_require__(14);
-
- var _emitter2 = _interopRequireDefault(_emitter);
+ var _vuePopper = __webpack_require__(13);
- var _util = __webpack_require__(219);
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- mixins: [_emitter2.default],
+ name: 'ElSelectDropdown',
- name: 'ElOption',
+ componentName: 'ElSelectDropdown',
- componentName: 'ElOption',
+ mixins: [_vuePopper2.default],
props: {
- value: {
- required: true
+ placement: {
+ default: 'bottom-start'
},
- label: [String, Number],
- created: Boolean,
- disabled: {
- type: Boolean,
- default: false
- }
- },
- data: function data() {
- return {
- index: -1,
- groupDisabled: false,
- visible: true,
- hitState: 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 || '';
- },
- parent: function parent() {
- var result = this.$parent;
- while (!result.isSelect) {
- result = result.$parent;
- }
- return result;
- },
- itemSelected: function itemSelected() {
- if (!this.parent.multiple) {
- return this.isEqual(this.value, this.parent.value);
- } else {
- return this.contains(this.parent.value, this.value);
- }
+ boundariesPadding: {
+ default: 0
},
- limitReached: function limitReached() {
- if (this.parent.multiple) {
- return !this.itemSelected && this.parent.value.length >= this.parent.multipleLimit && this.parent.multipleLimit > 0;
- } else {
- return false;
+
+ popperOptions: {
+ default: function _default() {
+ return {
+ forceAbsolute: true,
+ gpuAcceleration: false
+ };
}
}
},
- watch: {
- currentLabel: function currentLabel() {
- if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
- },
- value: function value() {
- if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
- }
+ data: function data() {
+ return {
+ minWidth: ''
+ };
},
- methods: {
- isEqual: function isEqual(a, b) {
- if (!this.isObject) {
- return a === b;
- } else {
- var valueKey = this.parent.valueKey;
- return (0, _util.getValueByPath)(a, valueKey) === (0, _util.getValueByPath)(b, valueKey);
- }
- },
- contains: function contains() {
- var _this = this;
-
- var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
- var target = arguments[1];
-
- if (!this.isObject) {
- return arr.indexOf(target) > -1;
- } else {
- var _ret = function () {
- var valueKey = _this.parent.valueKey;
- return {
- v: arr.some(function (item) {
- return (0, _util.getValueByPath)(item, valueKey) === (0, _util.getValueByPath)(target, valueKey);
- })
- };
- }();
- if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
- }
- },
- handleGroupDisabled: function handleGroupDisabled(val) {
- this.groupDisabled = val;
- },
- hoverItem: function hoverItem() {
- if (!this.disabled && !this.groupDisabled) {
- this.parent.hoverIndex = this.parent.options.indexOf(this);
- }
- },
- selectOptionClick: function selectOptionClick() {
- if (this.disabled !== true && this.groupDisabled !== true) {
- this.dispatch('ElSelect', 'handleOptionClick', this);
- }
- },
- queryChange: function queryChange(query) {
- // query 里如果有正则中的特殊字符,需要先将这些字符转义
- var parsedQuery = String(query).replace(/(\^|\(|\)|\[|\]|\$|\*|\+|\.|\?|\\|\{|\}|\|)/g, '\\$1');
- this.visible = new RegExp(parsedQuery, 'i').test(this.currentLabel) || this.created;
- if (!this.visible) {
- this.parent.filteredOptionsCount--;
- }
- },
- resetIndex: function resetIndex() {
- var _this2 = this;
+ computed: {
+ popperClass: function popperClass() {
+ return this.$parent.popperClass;
+ }
+ },
- this.$nextTick(function () {
- _this2.index = _this2.parent.options.indexOf(_this2);
- });
+ watch: {
+ '$parent.inputWidth': function $parentInputWidth() {
+ this.minWidth = this.$parent.$el.getBoundingClientRect().width + 'px';
}
},
- created: function created() {
- this.parent.options.push(this);
- this.parent.cachedOptions.push(this);
- this.parent.optionsCount++;
- this.parent.filteredOptionsCount++;
- this.index = this.parent.options.indexOf(this);
+ mounted: function mounted() {
+ var _this = this;
- this.$on('queryChange', this.queryChange);
- this.$on('handleGroupDisabled', this.handleGroupDisabled);
- this.$on('resetIndex', this.resetIndex);
- },
- beforeDestroy: function beforeDestroy() {
- this.dispatch('ElSelect', 'onOptionDestroy', 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);
}
- };
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
/***/ },
-/***/ 219:
+/***/ 269:
/***/ function(module, exports) {
- module.exports = __webpack_require__(6);
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-select-dropdown",
+ class: [{
+ 'is-multiple': _vm.$parent.multiple
+ }, _vm.popperClass],
+ style: ({
+ minWidth: _vm.minWidth
+ })
+ }, [_vm._t("default")], 2)
+ },staticRenderFns: []}
/***/ },
-/***/ 220:
+/***/ 270:
+/***/ function(module, exports) {
+
+ module.exports = __webpack_require__(26);
+
+/***/ },
+
+/***/ 271:
/***/ function(module, exports) {
module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('li', {
+ return _c('div', {
directives: [{
- name: "show",
- rawName: "v-show",
- value: (_vm.visible),
- expression: "visible"
+ name: "clickoutside",
+ rawName: "v-clickoutside",
+ value: (_vm.handleClose),
+ expression: "handleClose"
}],
- staticClass: "el-select-dropdown__item",
- class: {
- 'selected': _vm.itemSelected,
- 'is-disabled': _vm.disabled || _vm.groupDisabled || _vm.limitReached,
- 'hover': _vm.parent.hoverIndex === _vm.index
- },
+ staticClass: "el-select"
+ }, [(_vm.multiple) ? _c('div', {
+ ref: "tags",
+ staticClass: "el-select__tags",
+ style: ({
+ 'max-width': _vm.inputWidth - 32 + 'px'
+ }),
on: {
- "mouseenter": _vm.hoverItem,
"click": function($event) {
$event.stopPropagation();
- _vm.selectOptionClick($event)
+ _vm.toggleMenu($event)
}
}
- }, [_vm._t("default", [_c('span', [_vm._v(_vm._s(_vm.currentLabel))])])], 2)
+ }, [_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.disabled,
+ "hit": item.hitState,
+ "type": "primary",
+ "close-transition": ""
+ },
+ on: {
+ "close": function($event) {
+ _vm.deleteTag($event, item)
+ }
+ }
+ }, [_c('span', {
+ staticClass: "el-select__tags-text"
+ }, [_vm._v(_vm._s(item.currentLabel))])])
+ })), (_vm.filterable) ? _c('input', {
+ directives: [{
+ name: "model",
+ rawName: "v-model",
+ value: (_vm.query),
+ expression: "query"
+ }],
+ ref: "input",
+ staticClass: "el-select__input",
+ class: ("is-" + _vm.size),
+ style: ({
+ width: _vm.inputLength + 'px',
+ 'max-width': _vm.inputWidth - 42 + 'px'
+ }),
+ attrs: {
+ "type": "text",
+ "disabled": _vm.disabled,
+ "debounce": _vm.remote ? 300 : 0
+ },
+ domProps: {
+ "value": (_vm.query)
+ },
+ on: {
+ "focus": function($event) {
+ _vm.visible = true
+ },
+ "keyup": _vm.managePlaceholder,
+ "keydown": [_vm.resetInputState, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
+ $event.preventDefault();
+ _vm.navigateOptions('next')
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
+ $event.preventDefault();
+ _vm.navigateOptions('prev')
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
+ $event.preventDefault();
+ _vm.selectOption($event)
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "esc", 27)) { return null; }
+ $event.stopPropagation();
+ $event.preventDefault();
+ _vm.visible = false
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "delete", [8, 46])) { return null; }
+ _vm.deletePrevTag($event)
+ }],
+ "input": function($event) {
+ if ($event.target.composing) { return; }
+ _vm.query = $event.target.value
+ }
+ }
+ }) : _vm._e()], 1) : _vm._e(), _c('el-input', {
+ ref: "reference",
+ attrs: {
+ "type": "text",
+ "placeholder": _vm.currentPlaceholder,
+ "name": _vm.name,
+ "size": _vm.size,
+ "disabled": _vm.disabled,
+ "readonly": !_vm.filterable || _vm.multiple,
+ "validate-event": false,
+ "icon": _vm.iconClass
+ },
+ on: {
+ "focus": _vm.handleFocus,
+ "click": _vm.handleIconClick
+ },
+ nativeOn: {
+ "mousedown": function($event) {
+ _vm.handleMouseDown($event)
+ },
+ "keyup": function($event) {
+ _vm.debouncedOnInputChange($event)
+ },
+ "keydown": [function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
+ $event.preventDefault();
+ _vm.navigateOptions('next')
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
+ $event.preventDefault();
+ _vm.navigateOptions('prev')
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "enter", 13)) { return null; }
+ $event.preventDefault();
+ _vm.selectOption($event)
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "esc", 27)) { return null; }
+ $event.stopPropagation();
+ $event.preventDefault();
+ _vm.visible = false
+ }, function($event) {
+ if (!('button' in $event) && _vm._k($event.keyCode, "tab", 9)) { return null; }
+ _vm.visible = false
+ }],
+ "paste": function($event) {
+ _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"
+ }
+ }), _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"
+ }, [_c('el-scrollbar', {
+ directives: [{
+ name: "show",
+ rawName: "v-show",
+ value: (_vm.options.length > 0 && !_vm.loading),
+ expression: "options.length > 0 && !loading"
+ }],
+ class: {
+ 'is-empty': !_vm.allowCreate && _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.options.length === 0 || !_vm.allowCreate)) ? _c('p', {
+ staticClass: "el-select-dropdown__empty"
+ }, [_vm._v(_vm._s(_vm.emptyText))]) : _vm._e()], 1)], 1)], 1)
},staticRenderFns: []}
/***/ }
@@ -65554,1069 +64833,1742 @@ module.exports =
/******/ });
/***/ }),
-/* 48 */
-/***/ (function(module, exports) {
+/* 43 */
+/***/ (function(module, exports, __webpack_require__) {
-module.exports =
-/******/ (function(modules) { // webpackBootstrap
-/******/ // The module cache
-/******/ var installedModules = {};
+"use strict";
-/******/ // The require function
-/******/ function __webpack_require__(moduleId) {
-/******/ // Check if module is in cache
-/******/ if(installedModules[moduleId])
-/******/ return installedModules[moduleId].exports;
+exports.__esModule = true;
-/******/ // Create a new module (and put it into the cache)
-/******/ var module = installedModules[moduleId] = {
-/******/ exports: {},
-/******/ id: moduleId,
-/******/ loaded: false
-/******/ };
+var _vue = __webpack_require__(3);
-/******/ // Execute the module function
-/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
+var _vue2 = _interopRequireDefault(_vue);
-/******/ // Flag the module as loaded
-/******/ module.loaded = true;
+var _dom = __webpack_require__(4);
-/******/ // Return the exports of the module
-/******/ return module.exports;
-/******/ }
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var hasModal = false;
+
+var getModal = function getModal() {
+ if (_vue2.default.prototype.$isServer) return;
+ var modalDom = PopupManager.modalDom;
+ if (modalDom) {
+ hasModal = true;
+ } else {
+ hasModal = false;
+ modalDom = document.createElement('div');
+ PopupManager.modalDom = modalDom;
+
+ modalDom.addEventListener('touchmove', function (event) {
+ event.preventDefault();
+ event.stopPropagation();
+ });
+
+ modalDom.addEventListener('click', function () {
+ PopupManager.doOnModalClick && PopupManager.doOnModalClick();
+ });
+ }
+
+ return modalDom;
+};
+
+var instances = {};
+
+var PopupManager = {
+ zIndex: 2000,
+
+ modalFade: true,
+
+ getInstance: function getInstance(id) {
+ return instances[id];
+ },
+
+ register: function register(id, instance) {
+ if (id && instance) {
+ instances[id] = instance;
+ }
+ },
+
+ deregister: function deregister(id) {
+ if (id) {
+ instances[id] = null;
+ delete instances[id];
+ }
+ },
+
+ nextZIndex: function nextZIndex() {
+ return PopupManager.zIndex++;
+ },
+
+ modalStack: [],
+
+ doOnModalClick: function doOnModalClick() {
+ var topItem = PopupManager.modalStack[PopupManager.modalStack.length - 1];
+ if (!topItem) return;
+
+ var instance = PopupManager.getInstance(topItem.id);
+ if (instance && instance.closeOnClickModal) {
+ instance.close();
+ }
+ },
+
+ openModal: function openModal(id, zIndex, dom, modalClass, modalFade) {
+ if (_vue2.default.prototype.$isServer) return;
+ if (!id || zIndex === undefined) return;
+ this.modalFade = modalFade;
+
+ var modalStack = this.modalStack;
+
+ for (var i = 0, j = modalStack.length; i < j; i++) {
+ var item = modalStack[i];
+ if (item.id === id) {
+ return;
+ }
+ }
+
+ var modalDom = getModal();
+
+ (0, _dom.addClass)(modalDom, 'v-modal');
+ if (this.modalFade && !hasModal) {
+ (0, _dom.addClass)(modalDom, 'v-modal-enter');
+ }
+ if (modalClass) {
+ var classArr = modalClass.trim().split(/\s+/);
+ classArr.forEach(function (item) {
+ return (0, _dom.addClass)(modalDom, item);
+ });
+ }
+ setTimeout(function () {
+ (0, _dom.removeClass)(modalDom, 'v-modal-enter');
+ }, 200);
+
+ if (dom && dom.parentNode && dom.parentNode.nodeType !== 11) {
+ dom.parentNode.appendChild(modalDom);
+ } else {
+ document.body.appendChild(modalDom);
+ }
+
+ if (zIndex) {
+ modalDom.style.zIndex = zIndex;
+ }
+ modalDom.style.display = '';
+
+ this.modalStack.push({ id: id, zIndex: zIndex, modalClass: modalClass });
+ },
+
+ closeModal: function closeModal(id) {
+ var modalStack = this.modalStack;
+ var modalDom = getModal();
+
+ if (modalStack.length > 0) {
+ var topItem = modalStack[modalStack.length - 1];
+ if (topItem.id === id) {
+ if (topItem.modalClass) {
+ var classArr = topItem.modalClass.trim().split(/\s+/);
+ classArr.forEach(function (item) {
+ return (0, _dom.removeClass)(modalDom, item);
+ });
+ }
+
+ modalStack.pop();
+ if (modalStack.length > 0) {
+ modalDom.style.zIndex = modalStack[modalStack.length - 1].zIndex;
+ }
+ } else {
+ for (var i = modalStack.length - 1; i >= 0; i--) {
+ if (modalStack[i].id === id) {
+ modalStack.splice(i, 1);
+ break;
+ }
+ }
+ }
+ }
+
+ if (modalStack.length === 0) {
+ if (this.modalFade) {
+ (0, _dom.addClass)(modalDom, 'v-modal-leave');
+ }
+ setTimeout(function () {
+ if (modalStack.length === 0) {
+ if (modalDom.parentNode) modalDom.parentNode.removeChild(modalDom);
+ modalDom.style.display = 'none';
+ PopupManager.modalDom = undefined;
+ }
+ (0, _dom.removeClass)(modalDom, 'v-modal-leave');
+ }, 200);
+ }
+ }
+};
+var getTopPopup = function getTopPopup() {
+ if (_vue2.default.prototype.$isServer) return;
+ if (PopupManager.modalStack.length > 0) {
+ var topPopup = PopupManager.modalStack[PopupManager.modalStack.length - 1];
+ if (!topPopup) return;
+ var instance = PopupManager.getInstance(topPopup.id);
-/******/ // expose the modules object (__webpack_modules__)
-/******/ __webpack_require__.m = modules;
+ return instance;
+ }
+};
-/******/ // expose the module cache
-/******/ __webpack_require__.c = installedModules;
+if (!_vue2.default.prototype.$isServer) {
+ // handle `esc` key when the popup is shown
+ window.addEventListener('keydown', function (event) {
+ if (event.keyCode === 27) {
+ var topPopup = getTopPopup();
-/******/ // __webpack_public_path__
-/******/ __webpack_require__.p = "/dist/";
+ if (topPopup && topPopup.closeOnPressEscape) {
+ topPopup.handleClose ? topPopup.handleClose() : topPopup.handleAction ? topPopup.handleAction('cancel') : topPopup.close();
+ }
+ }
+ });
+}
-/******/ // Load entry module and return exports
-/******/ return __webpack_require__(0);
-/******/ })
-/************************************************************************/
-/******/ ({
+exports.default = PopupManager;
-/***/ 0:
-/***/ function(module, exports, __webpack_require__) {
+/***/ }),
+/* 44 */
+/***/ (function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(30);
+"use strict";
+var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;
+var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
-/***/ },
+/**
+ * @fileOverview Kickass library to create and place poppers near their reference elements.
+ * @version {{version}}
+ * @license
+ * Copyright (c) 2016 Federico Zivolo and contributors
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all
+ * copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ */
-/***/ 3:
-/***/ function(module, exports) {
+//
+// Cross module loader
+// Supported: Node, AMD, Browser globals
+//
+;(function (root, factory) {
+ if (true) {
+ // AMD. Register as an anonymous module.
+ !(__WEBPACK_AMD_DEFINE_FACTORY__ = (factory),
+ __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?
+ (__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :
+ __WEBPACK_AMD_DEFINE_FACTORY__),
+ __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
+ } else if ((typeof module === 'undefined' ? 'undefined' : _typeof(module)) === 'object' && module.exports) {
+ // Node. Does not work with strict CommonJS, but
+ // only CommonJS-like environments that support module.exports,
+ // like Node.
+ module.exports = factory();
+ } else {
+ // Browser globals (root is window)
+ root.Popper = factory();
+ }
+})(undefined, function () {
- /* globals __VUE_SSR_CONTEXT__ */
+ 'use strict';
- // this module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle
+ var root = window;
- module.exports = function normalizeComponent (
- rawScriptExports,
- compiledTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier /* server only */
- ) {
- var esModule
- var scriptExports = rawScriptExports = rawScriptExports || {}
+ // default options
+ var DEFAULTS = {
+ // placement of the popper
+ placement: 'bottom',
- // ES6 modules interop
- var type = typeof rawScriptExports.default
- if (type === 'object' || type === 'function') {
- esModule = rawScriptExports
- scriptExports = rawScriptExports.default
- }
+ gpuAcceleration: true,
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
+ // shift popper from its origin by the given amount of pixels (can be negative)
+ offset: 0,
- // render functions
- if (compiledTemplate) {
- options.render = compiledTemplate.render
- options.staticRenderFns = compiledTemplate.staticRenderFns
- }
+ // the element which will act as boundary of the popper
+ boundariesElement: 'viewport',
- // scopedId
- if (scopeId) {
- options._scopeId = scopeId
- }
+ // amount of pixel used to define a minimum distance between the boundaries and the popper
+ boundariesPadding: 5,
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context = context || (this.$vnode && this.$vnode.ssrContext)
- // 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 = injectStyles
- }
+ // popper will try to prevent overflow following this order,
+ // by default, then, it could overflow on the left and on top of the boundariesElement
+ preventOverflowOrder: ['left', 'right', 'top', 'bottom'],
- if (hook) {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
+ // the behavior used by flip to change the placement of the popper
+ flipBehavior: 'flip',
- return {
- esModule: esModule,
- exports: scriptExports,
- options: options
- }
- }
+ arrowElement: '[x-arrow]',
+ // list of functions used to modify the offsets before they are applied to the popper
+ modifiers: ['shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle'],
-/***/ },
+ modifiersIgnored: [],
-/***/ 30:
-/***/ function(module, exports, __webpack_require__) {
+ forceAbsolute: false
+ };
- 'use strict';
+ /**
+ * Create a new Popper.js instance
+ * @constructor Popper
+ * @param {HTMLElement} reference - The reference element used to position the popper
+ * @param {HTMLElement|Object} popper
+ * The HTML element used as popper, or a configuration used to generate the popper.
+ * @param {String} [popper.tagName='div'] The tag name of the generated popper.
+ * @param {Array} [popper.classNames=['popper']] Array of classes to apply to the generated popper.
+ * @param {Array} [popper.attributes] Array of attributes to apply, specify `attr:value` to assign a value to it.
+ * @param {HTMLElement|String} [popper.parent=window.document.body] The parent element, given as HTMLElement or as query string.
+ * @param {String} [popper.content=''] The content of the popper, it can be text, html, or node; if it is not text, set `contentType` to `html` or `node`.
+ * @param {String} [popper.contentType='text'] If `html`, the `content` will be parsed as HTML. If `node`, it will be appended as-is.
+ * @param {String} [popper.arrowTagName='div'] Same as `popper.tagName` but for the arrow element.
+ * @param {Array} [popper.arrowClassNames='popper__arrow'] Same as `popper.classNames` but for the arrow element.
+ * @param {String} [popper.arrowAttributes=['x-arrow']] Same as `popper.attributes` but for the arrow element.
+ * @param {Object} options
+ * @param {String} [options.placement=bottom]
+ * Placement of the popper accepted values: `top(-start, -end), right(-start, -end), bottom(-start, -right),
+ * left(-start, -end)`
+ *
+ * @param {HTMLElement|String} [options.arrowElement='[x-arrow]']
+ * The DOM Node used as arrow for the popper, or a CSS selector used to get the DOM node. It must be child of
+ * its parent Popper. Popper.js will apply to the given element the style required to align the arrow with its
+ * reference element.
+ * By default, it will look for a child node of the popper with the `x-arrow` attribute.
+ *
+ * @param {Boolean} [options.gpuAcceleration=true]
+ * When this property is set to true, the popper position will be applied using CSS3 translate3d, allowing the
+ * browser to use the GPU to accelerate the rendering.
+ * If set to false, the popper will be placed using `top` and `left` properties, not using the GPU.
+ *
+ * @param {Number} [options.offset=0]
+ * Amount of pixels the popper will be shifted (can be negative).
+ *
+ * @param {String|Element} [options.boundariesElement='viewport']
+ * The element which will define the boundaries of the popper position, the popper will never be placed outside
+ * of the defined boundaries (except if `keepTogether` is enabled)
+ *
+ * @param {Number} [options.boundariesPadding=5]
+ * Additional padding for the boundaries
+ *
+ * @param {Array} [options.preventOverflowOrder=['left', 'right', 'top', 'bottom']]
+ * Order used when Popper.js tries to avoid overflows from the boundaries, they will be checked in order,
+ * this means that the last ones will never overflow
+ *
+ * @param {String|Array} [options.flipBehavior='flip']
+ * The behavior used by the `flip` modifier to change the placement of the popper when the latter is trying to
+ * overlap its reference element. Defining `flip` as value, the placement will be flipped on
+ * its axis (`right - left`, `top - bottom`).
+ * You can even pass an array of placements (eg: `['right', 'left', 'top']` ) to manually specify
+ * how alter the placement when a flip is needed. (eg. in the above example, it would first flip from right to left,
+ * then, if even in its new placement, the popper is overlapping its reference element, it will be moved to top)
+ *
+ * @param {Array} [options.modifiers=[ 'shift', 'offset', 'preventOverflow', 'keepTogether', 'arrow', 'flip', 'applyStyle']]
+ * List of functions used to modify the data before they are applied to the popper, add your custom functions
+ * to this array to edit the offsets and placement.
+ * The function should reflect the @params and @returns of preventOverflow
+ *
+ * @param {Array} [options.modifiersIgnored=[]]
+ * Put here any built-in modifier name you want to exclude from the modifiers list
+ * The function should reflect the @params and @returns of preventOverflow
+ *
+ * @param {Boolean} [options.removeOnDestroy=false]
+ * Set to true if you want to automatically remove the popper when you call the `destroy` method.
+ */
+ function Popper(reference, popper, options) {
+ this._reference = reference.jquery ? reference[0] : reference;
+ this.state = {};
- exports.__esModule = true;
+ // if the popper variable is a configuration object, parse it to generate an HTMLElement
+ // generate a default popper if is not defined
+ var isNotDefined = typeof popper === 'undefined' || popper === null;
+ var isConfig = popper && Object.prototype.toString.call(popper) === '[object Object]';
+ if (isNotDefined || isConfig) {
+ this._popper = this.parse(isConfig ? popper : {});
+ }
+ // otherwise, use the given HTMLElement as popper
+ else {
+ this._popper = popper.jquery ? popper[0] : popper;
+ }
- var _button = __webpack_require__(31);
+ // with {} we create a new object with the options inside it
+ this._options = Object.assign({}, DEFAULTS, options);
- var _button2 = _interopRequireDefault(_button);
+ // refactoring modifiers' list
+ this._options.modifiers = this._options.modifiers.map(function (modifier) {
+ // remove ignored modifiers
+ if (this._options.modifiersIgnored.indexOf(modifier) !== -1) return;
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ // set the x-placement attribute before everything else because it could be used to add margins to the popper
+ // margins needs to be calculated to get the correct popper offsets
+ if (modifier === 'applyStyle') {
+ this._popper.setAttribute('x-placement', this._options.placement);
+ }
- /* istanbul ignore next */
- _button2.default.install = function (Vue) {
- Vue.component(_button2.default.name, _button2.default);
- };
+ // return predefined modifier identified by string or keep the custom one
+ return this.modifiers[modifier] || modifier;
+ }.bind(this));
- exports.default = _button2.default;
+ // make sure to apply the popper position before any computation
+ this.state.position = this._getPosition(this._popper, this._reference);
+ setStyle(this._popper, { position: this.state.position, top: 0 });
-/***/ },
+ // fire the first update to position the popper in the right place
+ this.update();
-/***/ 31:
-/***/ function(module, exports, __webpack_require__) {
+ // setup event listeners, they will take care of update the position in specific situations
+ this._setupEventListeners();
+ return this;
+ }
- var Component = __webpack_require__(3)(
- /* script */
- __webpack_require__(32),
- /* template */
- __webpack_require__(33),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ //
+ // Methods
+ //
+ /**
+ * Destroy the popper
+ * @method
+ * @memberof Popper
+ */
+ Popper.prototype.destroy = function () {
+ this._popper.removeAttribute('x-placement');
+ this._popper.style.left = '';
+ this._popper.style.position = '';
+ this._popper.style.top = '';
+ this._popper.style[getSupportedPropertyName('transform')] = '';
+ this._removeEventListeners();
- module.exports = Component.exports
+ // remove the popper if user explicity asked for the deletion on destroy
+ if (this._options.removeOnDestroy) {
+ this._popper.remove();
+ }
+ return this;
+ };
+ /**
+ * Updates the position of the popper, computing the new offsets and applying the new style
+ * @method
+ * @memberof Popper
+ */
+ Popper.prototype.update = function () {
+ var data = { instance: this, styles: {} };
-/***/ },
+ // store placement inside the data object, modifiers will be able to edit `placement` if needed
+ // and refer to _originalPlacement to know the original value
+ data.placement = this._options.placement;
+ data._originalPlacement = this._options.placement;
-/***/ 32:
-/***/ function(module, exports) {
+ // compute the popper and reference offsets and put them inside data.offsets
+ data.offsets = this._getOffsets(this._popper, this._reference, data.placement);
- 'use strict';
+ // get boundaries
+ data.boundaries = this._getBoundaries(data, this._options.boundariesPadding, this._options.boundariesElement);
- exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ data = this.runModifiers(data, this._options.modifiers);
- exports.default = {
- name: 'ElButton',
+ if (typeof this.state.updateCallback === 'function') {
+ this.state.updateCallback(data);
+ }
+ };
- 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
- },
+ /**
+ * If a function is passed, it will be executed after the initialization of popper with as first argument the Popper instance.
+ * @method
+ * @memberof Popper
+ * @param {Function} callback
+ */
+ Popper.prototype.onCreate = function (callback) {
+ // the createCallbacks return as first argument the popper instance
+ callback(this);
+ return this;
+ };
- methods: {
- handleClick: function handleClick(evt) {
- this.$emit('click', evt);
- },
- handleInnerClick: function handleInnerClick(evt) {
- if (this.disabled) {
- evt.stopPropagation();
- }
- }
- }
- };
+ /**
+ * If a function is passed, it will be executed after each update of popper with as first argument the set of coordinates and informations
+ * used to style popper and its arrow.
+ * NOTE: it doesn't get fired on the first call of the `Popper.update()` method inside the `Popper` constructor!
+ * @method
+ * @memberof Popper
+ * @param {Function} callback
+ */
+ Popper.prototype.onUpdate = function (callback) {
+ this.state.updateCallback = callback;
+ return this;
+ };
-/***/ },
+ /**
+ * Helper used to generate poppers from a configuration file
+ * @method
+ * @memberof Popper
+ * @param config {Object} configuration
+ * @returns {HTMLElement} popper
+ */
+ Popper.prototype.parse = function (config) {
+ var defaultConfig = {
+ tagName: 'div',
+ classNames: ['popper'],
+ attributes: [],
+ parent: root.document.body,
+ content: '',
+ contentType: 'text',
+ arrowTagName: 'div',
+ arrowClassNames: ['popper__arrow'],
+ arrowAttributes: ['x-arrow']
+ };
+ config = Object.assign({}, defaultConfig, config);
-/***/ 33:
-/***/ function(module, exports) {
+ var d = root.document;
- module.exports={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.size ? 'el-button--' + _vm.size : '', {
- 'is-disabled': _vm.disabled,
- 'is-loading': _vm.loading,
- 'is-plain': _vm.plain
- }
- ],
- attrs: {
- "disabled": _vm.disabled,
- "autofocus": _vm.autofocus,
- "type": _vm.nativeType
- },
- on: {
- "click": _vm.handleClick
- }
- }, [(_vm.loading) ? _c('i', {
- staticClass: "el-icon-loading",
- on: {
- "click": _vm.handleInnerClick
- }
- }) : _vm._e(), (_vm.icon && !_vm.loading) ? _c('i', {
- class: 'el-icon-' + _vm.icon,
- on: {
- "click": _vm.handleInnerClick
- }
- }) : _vm._e(), (_vm.$slots.default) ? _c('span', {
- on: {
- "click": _vm.handleInnerClick
- }
- }, [_vm._t("default")], 2) : _vm._e()])
- },staticRenderFns: []}
+ var popper = d.createElement(config.tagName);
+ addClassNames(popper, config.classNames);
+ addAttributes(popper, config.attributes);
+ if (config.contentType === 'node') {
+ popper.appendChild(config.content.jquery ? config.content[0] : config.content);
+ } else if (config.contentType === 'html') {
+ popper.innerHTML = config.content;
+ } else {
+ popper.textContent = config.content;
+ }
-/***/ }
+ if (config.arrowTagName) {
+ var arrow = d.createElement(config.arrowTagName);
+ addClassNames(arrow, config.arrowClassNames);
+ addAttributes(arrow, config.arrowAttributes);
+ popper.appendChild(arrow);
+ }
-/******/ });
+ var parent = config.parent.jquery ? config.parent[0] : config.parent;
-/***/ }),
-/* 49 */
-/***/ (function(module, exports) {
+ // if the given parent is a string, use it to match an element
+ // if more than one element is matched, the first one will be used as parent
+ // if no elements are matched, the script will throw an error
+ if (typeof parent === 'string') {
+ parent = d.querySelectorAll(config.parent);
+ if (parent.length > 1) {
+ console.warn('WARNING: the given `parent` query(' + config.parent + ') matched more than one element, the first one will be used');
+ }
+ if (parent.length === 0) {
+ throw 'ERROR: the given `parent` doesn\'t exists!';
+ }
+ parent = parent[0];
+ }
+ // if the given parent is a DOM nodes list or an array of nodes with more than one element,
+ // the first one will be used as parent
+ if (parent.length > 1 && parent instanceof Element === false) {
+ console.warn('WARNING: you have passed as parent a list of elements, the first one will be used');
+ parent = parent[0];
+ }
-module.exports =
-/******/ (function(modules) { // webpackBootstrap
-/******/ // The module cache
-/******/ var installedModules = {};
+ // append the generated popper to its parent
+ parent.appendChild(popper);
-/******/ // The require function
-/******/ function __webpack_require__(moduleId) {
+ return popper;
-/******/ // Check if module is in cache
-/******/ if(installedModules[moduleId])
-/******/ return installedModules[moduleId].exports;
+ /**
+ * Adds class names to the given element
+ * @function
+ * @ignore
+ * @param {HTMLElement} target
+ * @param {Array} classes
+ */
+ function addClassNames(element, classNames) {
+ classNames.forEach(function (className) {
+ element.classList.add(className);
+ });
+ }
-/******/ // Create a new module (and put it into the cache)
-/******/ var module = installedModules[moduleId] = {
-/******/ exports: {},
-/******/ id: moduleId,
-/******/ loaded: false
-/******/ };
+ /**
+ * Adds attributes to the given element
+ * @function
+ * @ignore
+ * @param {HTMLElement} target
+ * @param {Array} attributes
+ * @example
+ * addAttributes(element, [ 'data-info:foobar' ]);
+ */
+ function addAttributes(element, attributes) {
+ attributes.forEach(function (attribute) {
+ element.setAttribute(attribute.split(':')[0], attribute.split(':')[1] || '');
+ });
+ }
+ };
-/******/ // Execute the module function
-/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
+ /**
+ * Helper used to get the position which will be applied to the popper
+ * @method
+ * @memberof Popper
+ * @param config {HTMLElement} popper element
+ * @param reference {HTMLElement} reference element
+ * @returns {String} position
+ */
+ Popper.prototype._getPosition = function (popper, reference) {
+ var container = getOffsetParent(reference);
-/******/ // Flag the module as loaded
-/******/ module.loaded = true;
+ if (this._options.forceAbsolute) {
+ return 'absolute';
+ }
-/******/ // Return the exports of the module
-/******/ return module.exports;
-/******/ }
+ // Decide if the popper will be fixed
+ // If the reference element is inside a fixed context, the popper will be fixed as well to allow them to scroll together
+ var isParentFixed = isFixed(reference, container);
+ return isParentFixed ? 'fixed' : 'absolute';
+ };
+ /**
+ * Get offsets to the popper
+ * @method
+ * @memberof Popper
+ * @access private
+ * @param {Element} popper - the popper element
+ * @param {Element} reference - the reference element (the popper will be relative to this)
+ * @returns {Object} An object containing the offsets which will be applied to the popper
+ */
+ Popper.prototype._getOffsets = function (popper, reference, placement) {
+ placement = placement.split('-')[0];
+ var popperOffsets = {};
-/******/ // expose the modules object (__webpack_modules__)
-/******/ __webpack_require__.m = modules;
+ popperOffsets.position = this.state.position;
+ var isParentFixed = popperOffsets.position === 'fixed';
-/******/ // expose the module cache
-/******/ __webpack_require__.c = installedModules;
+ //
+ // Get reference element position
+ //
+ var referenceOffsets = getOffsetRectRelativeToCustomParent(reference, getOffsetParent(popper), isParentFixed);
-/******/ // __webpack_public_path__
-/******/ __webpack_require__.p = "/dist/";
+ //
+ // Get popper sizes
+ //
+ var popperRect = getOuterSizes(popper);
-/******/ // Load entry module and return exports
-/******/ return __webpack_require__(0);
-/******/ })
-/************************************************************************/
-/******/ ({
+ //
+ // Compute offsets of popper
+ //
-/***/ 0:
-/***/ function(module, exports, __webpack_require__) {
+ // depending by the popper placement we have to compute its offsets slightly differently
+ if (['right', 'left'].indexOf(placement) !== -1) {
+ popperOffsets.top = referenceOffsets.top + referenceOffsets.height / 2 - popperRect.height / 2;
+ if (placement === 'left') {
+ popperOffsets.left = referenceOffsets.left - popperRect.width;
+ } else {
+ popperOffsets.left = referenceOffsets.right;
+ }
+ } else {
+ popperOffsets.left = referenceOffsets.left + referenceOffsets.width / 2 - popperRect.width / 2;
+ if (placement === 'top') {
+ popperOffsets.top = referenceOffsets.top - popperRect.height;
+ } else {
+ popperOffsets.top = referenceOffsets.bottom;
+ }
+ }
- module.exports = __webpack_require__(34);
+ // Add width and height to our offsets object
+ popperOffsets.width = popperRect.width;
+ popperOffsets.height = popperRect.height;
+ return {
+ popper: popperOffsets,
+ reference: referenceOffsets
+ };
+ };
-/***/ },
+ /**
+ * Setup needed event listeners used to update the popper position
+ * @method
+ * @memberof Popper
+ * @access private
+ */
+ Popper.prototype._setupEventListeners = function () {
+ // NOTE: 1 DOM access here
+ this.state.updateBound = this.update.bind(this);
+ root.addEventListener('resize', this.state.updateBound);
+ // if the boundariesElement is window we don't need to listen for the scroll event
+ if (this._options.boundariesElement !== 'window') {
+ var target = getScrollParent(this._reference);
+ // here it could be both `body` or `documentElement` thanks to Firefox, we then check both
+ if (target === root.document.body || target === root.document.documentElement) {
+ target = root;
+ }
+ target.addEventListener('scroll', this.state.updateBound);
+ }
+ };
-/***/ 3:
-/***/ function(module, exports) {
+ /**
+ * Remove event listeners used to update the popper position
+ * @method
+ * @memberof Popper
+ * @access private
+ */
+ Popper.prototype._removeEventListeners = function () {
+ // NOTE: 1 DOM access here
+ root.removeEventListener('resize', this.state.updateBound);
+ if (this._options.boundariesElement !== 'window') {
+ var target = getScrollParent(this._reference);
+ // here it could be both `body` or `documentElement` thanks to Firefox, we then check both
+ if (target === root.document.body || target === root.document.documentElement) {
+ target = root;
+ }
+ target.removeEventListener('scroll', this.state.updateBound);
+ }
+ this.state.updateBound = null;
+ };
- /* globals __VUE_SSR_CONTEXT__ */
+ /**
+ * Computed the boundaries limits and return them
+ * @method
+ * @memberof Popper
+ * @access private
+ * @param {Object} data - Object containing the property "offsets" generated by `_getOffsets`
+ * @param {Number} padding - Boundaries padding
+ * @param {Element} boundariesElement - Element used to define the boundaries
+ * @returns {Object} Coordinates of the boundaries
+ */
+ Popper.prototype._getBoundaries = function (data, padding, boundariesElement) {
+ // NOTE: 1 DOM access here
+ var boundaries = {};
+ var width, height;
+ if (boundariesElement === 'window') {
+ var body = root.document.body,
+ html = root.document.documentElement;
- // this module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle
+ height = Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight);
+ width = Math.max(body.scrollWidth, body.offsetWidth, html.clientWidth, html.scrollWidth, html.offsetWidth);
- module.exports = function normalizeComponent (
- rawScriptExports,
- compiledTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier /* server only */
- ) {
- var esModule
- var scriptExports = rawScriptExports = rawScriptExports || {}
+ boundaries = {
+ top: 0,
+ right: width,
+ bottom: height,
+ left: 0
+ };
+ } else if (boundariesElement === 'viewport') {
+ var offsetParent = getOffsetParent(this._popper);
+ var scrollParent = getScrollParent(this._popper);
+ var offsetParentRect = getOffsetRect(offsetParent);
- // ES6 modules interop
- var type = typeof rawScriptExports.default
- if (type === 'object' || type === 'function') {
- esModule = rawScriptExports
- scriptExports = rawScriptExports.default
- }
+ // Thanks the fucking native API, `document.body.scrollTop` & `document.documentElement.scrollTop`
+ var getScrollTopValue = function getScrollTopValue(element) {
+ return element == document.body ? Math.max(document.documentElement.scrollTop, document.body.scrollTop) : element.scrollTop;
+ };
+ var getScrollLeftValue = function getScrollLeftValue(element) {
+ return element == document.body ? Math.max(document.documentElement.scrollLeft, document.body.scrollLeft) : element.scrollLeft;
+ };
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
+ // if the popper is fixed we don't have to substract scrolling from the boundaries
+ var scrollTop = data.offsets.popper.position === 'fixed' ? 0 : getScrollTopValue(scrollParent);
+ var scrollLeft = data.offsets.popper.position === 'fixed' ? 0 : getScrollLeftValue(scrollParent);
- // render functions
- if (compiledTemplate) {
- options.render = compiledTemplate.render
- options.staticRenderFns = compiledTemplate.staticRenderFns
- }
+ boundaries = {
+ top: 0 - (offsetParentRect.top - scrollTop),
+ right: root.document.documentElement.clientWidth - (offsetParentRect.left - scrollLeft),
+ bottom: root.document.documentElement.clientHeight - (offsetParentRect.top - scrollTop),
+ left: 0 - (offsetParentRect.left - scrollLeft)
+ };
+ } else {
+ if (getOffsetParent(this._popper) === boundariesElement) {
+ boundaries = {
+ top: 0,
+ left: 0,
+ right: boundariesElement.clientWidth,
+ bottom: boundariesElement.clientHeight
+ };
+ } else {
+ boundaries = getOffsetRect(boundariesElement);
+ }
+ }
+ boundaries.left += padding;
+ boundaries.right -= padding;
+ boundaries.top = boundaries.top + padding;
+ boundaries.bottom = boundaries.bottom - padding;
+ return boundaries;
+ };
- // scopedId
- if (scopeId) {
- options._scopeId = scopeId
- }
+ /**
+ * Loop trough the list of modifiers and run them in order, each of them will then edit the data object
+ * @method
+ * @memberof Popper
+ * @access public
+ * @param {Object} data
+ * @param {Array} modifiers
+ * @param {Function} ends
+ */
+ Popper.prototype.runModifiers = function (data, modifiers, ends) {
+ var modifiersToRun = modifiers.slice();
+ if (ends !== undefined) {
+ modifiersToRun = this._options.modifiers.slice(0, getArrayKeyIndex(this._options.modifiers, ends));
+ }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context = context || (this.$vnode && this.$vnode.ssrContext)
- // 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 = injectStyles
- }
+ modifiersToRun.forEach(function (modifier) {
+ if (isFunction(modifier)) {
+ data = modifier.call(this, data);
+ }
+ }.bind(this));
- if (hook) {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
+ return data;
+ };
- return {
- esModule: esModule,
- exports: scriptExports,
- options: options
- }
- }
+ /**
+ * Helper used to know if the given modifier depends from another one.
+ * @method
+ * @memberof Popper
+ * @param {String} requesting - name of requesting modifier
+ * @param {String} requested - name of requested modifier
+ * @returns {Boolean}
+ */
+ Popper.prototype.isModifierRequired = function (requesting, requested) {
+ var index = getArrayKeyIndex(this._options.modifiers, requesting);
+ return !!this._options.modifiers.slice(0, index).filter(function (modifier) {
+ return modifier === requested;
+ }).length;
+ };
+ //
+ // Modifiers
+ //
-/***/ },
+ /**
+ * Modifiers list
+ * @namespace Popper.modifiers
+ * @memberof Popper
+ * @type {Object}
+ */
+ Popper.prototype.modifiers = {};
-/***/ 34:
-/***/ function(module, exports, __webpack_require__) {
+ /**
+ * Apply the computed styles to the popper element
+ * @method
+ * @memberof Popper.modifiers
+ * @argument {Object} data - The data object generated by `update` method
+ * @returns {Object} The same data object
+ */
+ Popper.prototype.modifiers.applyStyle = function (data) {
+ // apply the final offsets to the popper
+ // NOTE: 1 DOM access here
+ var styles = {
+ position: data.offsets.popper.position
+ };
- 'use strict';
+ // round top and left to avoid blurry text
+ var left = Math.round(data.offsets.popper.left);
+ var top = Math.round(data.offsets.popper.top);
- exports.__esModule = true;
+ // if gpuAcceleration is set to true and transform is supported, we use `translate3d` to apply the position to the popper
+ // we automatically use the supported prefixed version if needed
+ var prefixedProperty;
+ if (this._options.gpuAcceleration && (prefixedProperty = getSupportedPropertyName('transform'))) {
+ styles[prefixedProperty] = 'translate3d(' + left + 'px, ' + top + 'px, 0)';
+ styles.top = 0;
+ styles.left = 0;
+ }
+ // othwerise, we use the standard `left` and `top` properties
+ else {
+ styles.left = left;
+ styles.top = top;
+ }
- var _buttonGroup = __webpack_require__(35);
+ // any property present in `data.styles` will be applied to the popper,
+ // in this way we can make the 3rd party modifiers add custom styles to it
+ // Be aware, modifiers could override the properties defined in the previous
+ // lines of this modifier!
+ Object.assign(styles, data.styles);
- var _buttonGroup2 = _interopRequireDefault(_buttonGroup);
+ setStyle(this._popper, styles);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ // set an attribute which will be useful to style the tooltip (use it to properly position its arrow)
+ // NOTE: 1 DOM access here
+ this._popper.setAttribute('x-placement', data.placement);
- /* istanbul ignore next */
- _buttonGroup2.default.install = function (Vue) {
- Vue.component(_buttonGroup2.default.name, _buttonGroup2.default);
- };
+ // if the arrow modifier is required and the arrow style has been computed, apply the arrow style
+ if (this.isModifierRequired(this.modifiers.applyStyle, this.modifiers.arrow) && data.offsets.arrow) {
+ setStyle(data.arrowElement, data.offsets.arrow);
+ }
- exports.default = _buttonGroup2.default;
+ return data;
+ };
-/***/ },
+ /**
+ * Modifier used to shift the popper on the start or end of its reference element side
+ * @method
+ * @memberof Popper.modifiers
+ * @argument {Object} data - The data object generated by `update` method
+ * @returns {Object} The data object, properly modified
+ */
+ Popper.prototype.modifiers.shift = function (data) {
+ var placement = data.placement;
+ var basePlacement = placement.split('-')[0];
+ var shiftVariation = placement.split('-')[1];
-/***/ 35:
-/***/ function(module, exports, __webpack_require__) {
+ // if shift shiftVariation is specified, run the modifier
+ if (shiftVariation) {
+ var reference = data.offsets.reference;
+ var popper = getPopperClientRect(data.offsets.popper);
- var Component = __webpack_require__(3)(
- /* script */
- __webpack_require__(36),
- /* template */
- __webpack_require__(37),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+ var shiftOffsets = {
+ y: {
+ start: { top: reference.top },
+ end: { top: reference.top + reference.height - popper.height }
+ },
+ x: {
+ start: { left: reference.left },
+ end: { left: reference.left + reference.width - popper.width }
+ }
+ };
- module.exports = Component.exports
+ var axis = ['bottom', 'top'].indexOf(basePlacement) !== -1 ? 'x' : 'y';
+
+ data.offsets.popper = Object.assign(popper, shiftOffsets[axis][shiftVariation]);
+ }
+
+ return data;
+ };
+
+ /**
+ * Modifier used to make sure the popper does not overflows from it's boundaries
+ * @method
+ * @memberof Popper.modifiers
+ * @argument {Object} data - The data object generated by `update` method
+ * @returns {Object} The data object, properly modified
+ */
+ Popper.prototype.modifiers.preventOverflow = function (data) {
+ var order = this._options.preventOverflowOrder;
+ var popper = getPopperClientRect(data.offsets.popper);
+
+ var check = {
+ left: function left() {
+ var left = popper.left;
+ if (popper.left < data.boundaries.left) {
+ left = Math.max(popper.left, data.boundaries.left);
+ }
+ return { left: left };
+ },
+ right: function right() {
+ var left = popper.left;
+ if (popper.right > data.boundaries.right) {
+ left = Math.min(popper.left, data.boundaries.right - popper.width);
+ }
+ return { left: left };
+ },
+ top: function top() {
+ var top = popper.top;
+ if (popper.top < data.boundaries.top) {
+ top = Math.max(popper.top, data.boundaries.top);
+ }
+ return { top: top };
+ },
+ bottom: function bottom() {
+ var top = popper.top;
+ if (popper.bottom > data.boundaries.bottom) {
+ top = Math.min(popper.top, data.boundaries.bottom - popper.height);
+ }
+ return { top: top };
+ }
+ };
+ order.forEach(function (direction) {
+ data.offsets.popper = Object.assign(popper, check[direction]());
+ });
-/***/ },
+ return data;
+ };
-/***/ 36:
-/***/ function(module, exports) {
+ /**
+ * Modifier used to make sure the popper is always near its reference
+ * @method
+ * @memberof Popper.modifiers
+ * @argument {Object} data - The data object generated by _update method
+ * @returns {Object} The data object, properly modified
+ */
+ Popper.prototype.modifiers.keepTogether = function (data) {
+ var popper = getPopperClientRect(data.offsets.popper);
+ var reference = data.offsets.reference;
+ var f = Math.floor;
- 'use strict';
+ if (popper.right < f(reference.left)) {
+ data.offsets.popper.left = f(reference.left) - popper.width;
+ }
+ if (popper.left > f(reference.right)) {
+ data.offsets.popper.left = f(reference.right);
+ }
+ if (popper.bottom < f(reference.top)) {
+ data.offsets.popper.top = f(reference.top) - popper.height;
+ }
+ if (popper.top > f(reference.bottom)) {
+ data.offsets.popper.top = f(reference.bottom);
+ }
- exports.__esModule = true;
- //
- //
- //
- //
- //
+ return data;
+ };
- /**
- * button
- * @module components/basic/menu
- * @desc 用于按钮组
- * @param {string} label - 名称
- */
- exports.default = {
- name: 'ElButtonGroup'
- };
+ /**
+ * Modifier used to flip the placement of the popper when the latter is starting overlapping its reference element.
+ * Requires the `preventOverflow` modifier before it in order to work.
+ * **NOTE:** This modifier will run all its previous modifiers everytime it tries to flip the popper!
+ * @method
+ * @memberof Popper.modifiers
+ * @argument {Object} data - The data object generated by _update method
+ * @returns {Object} The data object, properly modified
+ */
+ Popper.prototype.modifiers.flip = function (data) {
+ // check if preventOverflow is in the list of modifiers before the flip modifier.
+ // otherwise flip would not work as expected.
+ if (!this.isModifierRequired(this.modifiers.flip, this.modifiers.preventOverflow)) {
+ console.warn('WARNING: preventOverflow modifier is required by flip modifier in order to work, be sure to include it before flip!');
+ return data;
+ }
-/***/ },
+ if (data.flipped && data.placement === data._originalPlacement) {
+ // seems like flip is trying to loop, probably there's not enough space on any of the flippable sides
+ return data;
+ }
-/***/ 37:
-/***/ function(module, exports) {
+ var placement = data.placement.split('-')[0];
+ var placementOpposite = getOppositePlacement(placement);
+ var variation = data.placement.split('-')[1] || '';
- module.exports={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)
- },staticRenderFns: []}
+ var flipOrder = [];
+ if (this._options.flipBehavior === 'flip') {
+ flipOrder = [placement, placementOpposite];
+ } else {
+ flipOrder = this._options.flipBehavior;
+ }
-/***/ }
+ flipOrder.forEach(function (step, index) {
+ if (placement !== step || flipOrder.length === index + 1) {
+ return;
+ }
-/******/ });
+ placement = data.placement.split('-')[0];
+ placementOpposite = getOppositePlacement(placement);
-/***/ }),
-/* 50 */
-/***/ (function(module, exports, __webpack_require__) {
+ var popperOffsets = getPopperClientRect(data.offsets.popper);
-"use strict";
+ // this boolean is used to distinguish right and bottom from top and left
+ // they need different computations to get flipped
+ var a = ['right', 'bottom'].indexOf(placement) !== -1;
+ // using Math.floor because the reference offsets may contain decimals we are not going to consider here
+ if (a && Math.floor(data.offsets.reference[placement]) > Math.floor(popperOffsets[placementOpposite]) || !a && Math.floor(data.offsets.reference[placement]) < Math.floor(popperOffsets[placementOpposite])) {
+ // we'll use this boolean to detect any flip loop
+ data.flipped = true;
+ data.placement = flipOrder[index + 1];
+ if (variation) {
+ data.placement += '-' + variation;
+ }
+ data.offsets.popper = this._getOffsets(this._popper, this._reference, data.placement).popper;
-exports.__esModule = true;
+ data = this.runModifiers(data, this._options.modifiers, this._flip);
+ }
+ }.bind(this));
+ return data;
+ };
-var _dom = __webpack_require__(4);
+ /**
+ * Modifier used to add an offset to the popper, useful if you more granularity positioning your popper.
+ * The offsets will shift the popper on the side of its reference element.
+ * @method
+ * @memberof Popper.modifiers
+ * @argument {Object} data - The data object generated by _update method
+ * @returns {Object} The data object, properly modified
+ */
+ Popper.prototype.modifiers.offset = function (data) {
+ var offset = this._options.offset;
+ var popper = data.offsets.popper;
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+ if (data.placement.indexOf('left') !== -1) {
+ popper.top -= offset;
+ } else if (data.placement.indexOf('right') !== -1) {
+ popper.top += offset;
+ } else if (data.placement.indexOf('top') !== -1) {
+ popper.left -= offset;
+ } else if (data.placement.indexOf('bottom') !== -1) {
+ popper.left += offset;
+ }
+ return data;
+ };
-var Transition = function () {
- function Transition() {
- _classCallCheck(this, Transition);
- }
+ /**
+ * Modifier used to move the arrows on the edge of the popper to make sure them are always between the popper and the reference element
+ * It will use the CSS outer size of the arrow element to know how many pixels of conjuction are needed
+ * @method
+ * @memberof Popper.modifiers
+ * @argument {Object} data - The data object generated by _update method
+ * @returns {Object} The data object, properly modified
+ */
+ Popper.prototype.modifiers.arrow = function (data) {
+ var arrow = this._options.arrowElement;
- Transition.prototype.beforeEnter = function beforeEnter(el) {
- (0, _dom.addClass)(el, 'collapse-transition');
- if (!el.dataset) el.dataset = {};
+ // if the arrowElement is a string, suppose it's a CSS selector
+ if (typeof arrow === 'string') {
+ arrow = this._popper.querySelector(arrow);
+ }
- el.dataset.oldPaddingTop = el.style.paddingTop;
- el.dataset.oldPaddingBottom = el.style.paddingBottom;
+ // if arrow element is not found, don't run the modifier
+ if (!arrow) {
+ return data;
+ }
- el.style.height = '0';
- el.style.paddingTop = 0;
- el.style.paddingBottom = 0;
- };
+ // the arrow element must be child of its popper
+ if (!this._popper.contains(arrow)) {
+ console.warn('WARNING: `arrowElement` must be child of its popper element!');
+ return data;
+ }
- Transition.prototype.enter = function enter(el) {
- el.dataset.oldOverflow = el.style.overflow;
- if (el.scrollHeight !== 0) {
- el.style.height = el.scrollHeight + 'px';
- el.style.paddingTop = el.dataset.oldPaddingTop;
- el.style.paddingBottom = el.dataset.oldPaddingBottom;
- } else {
- el.style.height = '';
- el.style.paddingTop = el.dataset.oldPaddingTop;
- el.style.paddingBottom = el.dataset.oldPaddingBottom;
- }
+ // arrow depends on keepTogether in order to work
+ if (!this.isModifierRequired(this.modifiers.arrow, this.modifiers.keepTogether)) {
+ console.warn('WARNING: keepTogether modifier is required by arrow modifier in order to work, be sure to include it before arrow!');
+ return data;
+ }
- el.style.overflow = 'hidden';
- };
+ var arrowStyle = {};
+ var placement = data.placement.split('-')[0];
+ var popper = getPopperClientRect(data.offsets.popper);
+ var reference = data.offsets.reference;
+ var isVertical = ['left', 'right'].indexOf(placement) !== -1;
- Transition.prototype.afterEnter = function afterEnter(el) {
- // for safari: remove class then reset height is necessary
- (0, _dom.removeClass)(el, 'collapse-transition');
- el.style.height = '';
- el.style.overflow = el.dataset.oldOverflow;
- };
+ var len = isVertical ? 'height' : 'width';
+ var side = isVertical ? 'top' : 'left';
+ var altSide = isVertical ? 'left' : 'top';
+ var opSide = isVertical ? 'bottom' : 'right';
+ var arrowSize = getOuterSizes(arrow)[len];
- Transition.prototype.beforeLeave = function beforeLeave(el) {
- if (!el.dataset) el.dataset = {};
- el.dataset.oldPaddingTop = el.style.paddingTop;
- el.dataset.oldPaddingBottom = el.style.paddingBottom;
- el.dataset.oldOverflow = el.style.overflow;
+ //
+ // extends keepTogether behavior making sure the popper and its reference have enough pixels in conjuction
+ //
- el.style.height = el.scrollHeight + 'px';
- el.style.overflow = 'hidden';
- };
+ // top/left side
+ if (reference[opSide] - arrowSize < popper[side]) {
+ data.offsets.popper[side] -= popper[side] - (reference[opSide] - arrowSize);
+ }
+ // bottom/right side
+ if (reference[side] + arrowSize > popper[opSide]) {
+ data.offsets.popper[side] += reference[side] + arrowSize - popper[opSide];
+ }
- Transition.prototype.leave = function leave(el) {
- if (el.scrollHeight !== 0) {
- // for safari: add class after set height, or it will jump to zero height suddenly, weired
- (0, _dom.addClass)(el, 'collapse-transition');
- el.style.height = 0;
- el.style.paddingTop = 0;
- el.style.paddingBottom = 0;
- }
- };
+ // compute center of the popper
+ var center = reference[side] + reference[len] / 2 - arrowSize / 2;
- Transition.prototype.afterLeave = function afterLeave(el) {
- (0, _dom.removeClass)(el, 'collapse-transition');
- el.style.height = '';
- el.style.overflow = el.dataset.oldOverflow;
- el.style.paddingTop = el.dataset.oldPaddingTop;
- el.style.paddingBottom = el.dataset.oldPaddingBottom;
- };
+ var sideValue = center - popper[side];
- return Transition;
-}();
+ // prevent arrow from being placed not contiguously to its popper
+ sideValue = Math.max(Math.min(popper[len] - arrowSize - 3, sideValue), 3);
+ arrowStyle[side] = sideValue;
+ arrowStyle[altSide] = ''; // make sure to remove any old style from the arrow
-exports.default = {
- name: 'ElCollapseTransition',
- functional: true,
- render: function render(h, _ref) {
- var children = _ref.children;
+ data.offsets.arrow = arrowStyle;
+ data.arrowElement = arrow;
- var data = {
- on: new Transition()
+ return data;
};
- return h('transition', data, children);
- }
-};
-
-/***/ }),
-/* 51 */
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports =
-/******/ (function(modules) { // webpackBootstrap
-/******/ // The module cache
-/******/ var installedModules = {};
-
-/******/ // The require function
-/******/ function __webpack_require__(moduleId) {
+ //
+ // Helpers
+ //
-/******/ // Check if module is in cache
-/******/ if(installedModules[moduleId])
-/******/ return installedModules[moduleId].exports;
+ /**
+ * Get the outer sizes of the given element (offset size + margins)
+ * @function
+ * @ignore
+ * @argument {Element} element
+ * @returns {Object} object containing width and height properties
+ */
+ function getOuterSizes(element) {
+ // NOTE: 1 DOM access here
+ var _display = element.style.display,
+ _visibility = element.style.visibility;
+ element.style.display = 'block';element.style.visibility = 'hidden';
+ var calcWidthToForceRepaint = element.offsetWidth;
-/******/ // Create a new module (and put it into the cache)
-/******/ var module = installedModules[moduleId] = {
-/******/ exports: {},
-/******/ id: moduleId,
-/******/ loaded: false
-/******/ };
+ // original method
+ var styles = root.getComputedStyle(element);
+ var x = parseFloat(styles.marginTop) + parseFloat(styles.marginBottom);
+ var y = parseFloat(styles.marginLeft) + parseFloat(styles.marginRight);
+ var result = { width: element.offsetWidth + y, height: element.offsetHeight + x };
-/******/ // Execute the module function
-/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
+ // reset element styles
+ element.style.display = _display;element.style.visibility = _visibility;
+ return result;
+ }
-/******/ // Flag the module as loaded
-/******/ module.loaded = true;
+ /**
+ * Get the opposite placement of the given one/
+ * @function
+ * @ignore
+ * @argument {String} placement
+ * @returns {String} flipped placement
+ */
+ function getOppositePlacement(placement) {
+ var hash = { left: 'right', right: 'left', bottom: 'top', top: 'bottom' };
+ return placement.replace(/left|right|bottom|top/g, function (matched) {
+ return hash[matched];
+ });
+ }
-/******/ // Return the exports of the module
-/******/ return module.exports;
-/******/ }
+ /**
+ * Given the popper offsets, generate an output similar to getBoundingClientRect
+ * @function
+ * @ignore
+ * @argument {Object} popperOffsets
+ * @returns {Object} ClientRect like output
+ */
+ function getPopperClientRect(popperOffsets) {
+ var offsets = Object.assign({}, popperOffsets);
+ offsets.right = offsets.left + offsets.width;
+ offsets.bottom = offsets.top + offsets.height;
+ return offsets;
+ }
+ /**
+ * Given an array and the key to find, returns its index
+ * @function
+ * @ignore
+ * @argument {Array} arr
+ * @argument keyToFind
+ * @returns index or null
+ */
+ function getArrayKeyIndex(arr, keyToFind) {
+ var i = 0,
+ key;
+ for (key in arr) {
+ if (arr[key] === keyToFind) {
+ return i;
+ }
+ i++;
+ }
+ return null;
+ }
-/******/ // expose the modules object (__webpack_modules__)
-/******/ __webpack_require__.m = modules;
+ /**
+ * Get CSS computed property of the given element
+ * @function
+ * @ignore
+ * @argument {Eement} element
+ * @argument {String} property
+ */
+ function getStyleComputedProperty(element, property) {
+ // NOTE: 1 DOM access here
+ var css = root.getComputedStyle(element, null);
+ return css[property];
+ }
-/******/ // expose the module cache
-/******/ __webpack_require__.c = installedModules;
+ /**
+ * Returns the offset parent of the given element
+ * @function
+ * @ignore
+ * @argument {Element} element
+ * @returns {Element} offset parent
+ */
+ function getOffsetParent(element) {
+ // NOTE: 1 DOM access here
+ var offsetParent = element.offsetParent;
+ return offsetParent === root.document.body || !offsetParent ? root.document.documentElement : offsetParent;
+ }
-/******/ // __webpack_public_path__
-/******/ __webpack_require__.p = "/dist/";
+ /**
+ * Returns the scrolling parent of the given element
+ * @function
+ * @ignore
+ * @argument {Element} element
+ * @returns {Element} offset parent
+ */
+ function getScrollParent(element) {
+ var parent = element.parentNode;
-/******/ // Load entry module and return exports
-/******/ return __webpack_require__(0);
-/******/ })
-/************************************************************************/
-/******/ ({
+ if (!parent) {
+ return element;
+ }
-/***/ 0:
-/***/ function(module, exports, __webpack_require__) {
+ if (parent === root.document) {
+ // Firefox puts the scrollTOp value on `documentElement` instead of `body`, we then check which of them is
+ // greater than 0 and return the proper element
+ if (root.document.body.scrollTop) {
+ return root.document.body;
+ } else {
+ return root.document.documentElement;
+ }
+ }
- module.exports = __webpack_require__(65);
+ // Firefox want us to check `-x` and `-y` variations as well
+ if (['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow')) !== -1 || ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-x')) !== -1 || ['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-y')) !== -1) {
+ // If the detected scrollParent is body, we perform an additional check on its parentNode
+ // in this way we'll get body if the browser is Chrome-ish, or documentElement otherwise
+ // fixes issue #65
+ return parent;
+ }
+ return getScrollParent(element.parentNode);
+ }
+ /**
+ * Check if the given element is fixed or is inside a fixed parent
+ * @function
+ * @ignore
+ * @argument {Element} element
+ * @argument {Element} customContainer
+ * @returns {Boolean} answer to "isFixed?"
+ */
+ function isFixed(element) {
+ if (element === root.document.body) {
+ return false;
+ }
+ if (getStyleComputedProperty(element, 'position') === 'fixed') {
+ return true;
+ }
+ return element.parentNode ? isFixed(element.parentNode) : element;
+ }
-/***/ },
+ /**
+ * Set the style to the given popper
+ * @function
+ * @ignore
+ * @argument {Element} element - Element to apply the style to
+ * @argument {Object} styles - Object with a list of properties and values which will be applied to the element
+ */
+ function setStyle(element, styles) {
+ function is_numeric(n) {
+ return n !== '' && !isNaN(parseFloat(n)) && isFinite(n);
+ }
+ Object.keys(styles).forEach(function (prop) {
+ var unit = '';
+ // add unit if the value is numeric and is one of the following
+ if (['width', 'height', 'top', 'right', 'bottom', 'left'].indexOf(prop) !== -1 && is_numeric(styles[prop])) {
+ unit = 'px';
+ }
+ element.style[prop] = styles[prop] + unit;
+ });
+ }
-/***/ 3:
-/***/ function(module, exports) {
+ /**
+ * Check if the given variable is a function
+ * @function
+ * @ignore
+ * @argument {*} functionToCheck - variable to check
+ * @returns {Boolean} answer to: is a function?
+ */
+ function isFunction(functionToCheck) {
+ var getType = {};
+ return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
+ }
- /* globals __VUE_SSR_CONTEXT__ */
+ /**
+ * Get the position of the given element, relative to its offset parent
+ * @function
+ * @ignore
+ * @param {Element} element
+ * @return {Object} position - Coordinates of the element and its `scrollTop`
+ */
+ function getOffsetRect(element) {
+ var elementRect = {
+ width: element.offsetWidth,
+ height: element.offsetHeight,
+ left: element.offsetLeft,
+ top: element.offsetTop
+ };
- // this module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle
+ elementRect.right = elementRect.left + elementRect.width;
+ elementRect.bottom = elementRect.top + elementRect.height;
- module.exports = function normalizeComponent (
- rawScriptExports,
- compiledTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier /* server only */
- ) {
- var esModule
- var scriptExports = rawScriptExports = rawScriptExports || {}
+ // position
+ return elementRect;
+ }
- // ES6 modules interop
- var type = typeof rawScriptExports.default
- if (type === 'object' || type === 'function') {
- esModule = rawScriptExports
- scriptExports = rawScriptExports.default
- }
+ /**
+ * Get bounding client rect of given element
+ * @function
+ * @ignore
+ * @param {HTMLElement} element
+ * @return {Object} client rect
+ */
+ function getBoundingClientRect(element) {
+ var rect = element.getBoundingClientRect();
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
+ // whether the IE version is lower than 11
+ var isIE = navigator.userAgent.indexOf("MSIE") != -1;
- // render functions
- if (compiledTemplate) {
- options.render = compiledTemplate.render
- options.staticRenderFns = compiledTemplate.staticRenderFns
- }
+ // fix ie document bounding top always 0 bug
+ var rectTop = isIE && element.tagName === 'HTML' ? -element.scrollTop : rect.top;
- // scopedId
- if (scopeId) {
- options._scopeId = scopeId
- }
+ return {
+ left: rect.left,
+ top: rectTop,
+ right: rect.right,
+ bottom: rect.bottom,
+ width: rect.right - rect.left,
+ height: rect.bottom - rectTop
+ };
+ }
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context = context || (this.$vnode && this.$vnode.ssrContext)
- // 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 = injectStyles
- }
+ /**
+ * Given an element and one of its parents, return the offset
+ * @function
+ * @ignore
+ * @param {HTMLElement} element
+ * @param {HTMLElement} parent
+ * @return {Object} rect
+ */
+ function getOffsetRectRelativeToCustomParent(element, parent, fixed) {
+ var elementRect = getBoundingClientRect(element);
+ var parentRect = getBoundingClientRect(parent);
- if (hook) {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
+ if (fixed) {
+ var scrollParent = getScrollParent(parent);
+ parentRect.top += scrollParent.scrollTop;
+ parentRect.bottom += scrollParent.scrollTop;
+ parentRect.left += scrollParent.scrollLeft;
+ parentRect.right += scrollParent.scrollLeft;
+ }
- return {
- esModule: esModule,
- exports: scriptExports,
- options: options
- }
- }
+ var rect = {
+ top: elementRect.top - parentRect.top,
+ left: elementRect.left - parentRect.left,
+ bottom: elementRect.top - parentRect.top + elementRect.height,
+ right: elementRect.left - parentRect.left + elementRect.width,
+ width: elementRect.width,
+ height: elementRect.height
+ };
+ return rect;
+ }
+ /**
+ * Get the prefixed supported property name
+ * @function
+ * @ignore
+ * @argument {String} property (camelCase)
+ * @returns {String} prefixed property (camelCase)
+ */
+ function getSupportedPropertyName(property) {
+ var prefixes = ['', 'ms', 'webkit', 'moz', 'o'];
-/***/ },
+ for (var i = 0; i < prefixes.length; i++) {
+ var toCheck = prefixes[i] ? prefixes[i] + property.charAt(0).toUpperCase() + property.slice(1) : property;
+ if (typeof root.document.body.style[toCheck] !== 'undefined') {
+ return toCheck;
+ }
+ }
+ return null;
+ }
-/***/ 14:
-/***/ function(module, exports) {
+ /**
+ * The Object.assign() method is used to copy the values of all enumerable own properties from one or more source
+ * objects to a target object. It will return the target object.
+ * This polyfill doesn't support symbol properties, since ES5 doesn't have symbols anyway
+ * Source: https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign
+ * @function
+ * @ignore
+ */
+ if (!Object.assign) {
+ Object.defineProperty(Object, 'assign', {
+ enumerable: false,
+ configurable: true,
+ writable: true,
+ value: function value(target) {
+ if (target === undefined || target === null) {
+ throw new TypeError('Cannot convert first argument to object');
+ }
- module.exports = __webpack_require__(5);
+ var to = Object(target);
+ for (var i = 1; i < arguments.length; i++) {
+ var nextSource = arguments[i];
+ if (nextSource === undefined || nextSource === null) {
+ continue;
+ }
+ nextSource = Object(nextSource);
-/***/ },
+ var keysArray = Object.keys(nextSource);
+ for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex++) {
+ var nextKey = keysArray[nextIndex];
+ var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);
+ if (desc !== undefined && desc.enumerable) {
+ to[nextKey] = nextSource[nextKey];
+ }
+ }
+ }
+ return to;
+ }
+ });
+ }
-/***/ 65:
-/***/ function(module, exports, __webpack_require__) {
+ return Popper;
+});
- 'use strict';
+/***/ }),
+/* 45 */
+/***/ (function(module, exports, __webpack_require__) {
- exports.__esModule = true;
+"use strict";
- var _checkbox = __webpack_require__(66);
- var _checkbox2 = _interopRequireDefault(_checkbox);
+exports.__esModule = true;
+exports.default = {
+ el: {
+ colorpicker: {
+ confirm: '确定',
+ clear: '清空'
+ },
+ datepicker: {
+ now: '此刻',
+ today: '今天',
+ cancel: '取消',
+ clear: '清空',
+ confirm: '确定',
+ selectDate: '选择日期',
+ selectTime: '选择时间',
+ startDate: '开始日期',
+ startTime: '开始时间',
+ endDate: '结束日期',
+ endTime: '结束时间',
+ year: '年',
+ month1: '1 月',
+ month2: '2 月',
+ month3: '3 月',
+ month4: '4 月',
+ month5: '5 月',
+ month6: '6 月',
+ month7: '7 月',
+ month8: '8 月',
+ month9: '9 月',
+ month10: '10 月',
+ month11: '11 月',
+ month12: '12 月',
+ // week: '周次',
+ weeks: {
+ sun: '日',
+ mon: '一',
+ tue: '二',
+ wed: '三',
+ thu: '四',
+ fri: '五',
+ sat: '六'
+ },
+ months: {
+ jan: '一月',
+ feb: '二月',
+ mar: '三月',
+ apr: '四月',
+ may: '五月',
+ jun: '六月',
+ jul: '七月',
+ aug: '八月',
+ sep: '九月',
+ oct: '十月',
+ nov: '十一月',
+ dec: '十二月'
+ }
+ },
+ select: {
+ loading: '加载中',
+ noMatch: '无匹配数据',
+ noData: '无数据',
+ placeholder: '请选择'
+ },
+ cascader: {
+ noMatch: '无匹配数据',
+ loading: '加载中',
+ placeholder: '请选择'
+ },
+ pagination: {
+ goto: '前往',
+ pagesize: '条/页',
+ total: '共 {total} 条',
+ pageClassifier: '页'
+ },
+ messagebox: {
+ title: '提示',
+ confirm: '确定',
+ cancel: '取消',
+ error: '输入的数据不合法!'
+ },
+ upload: {
+ delete: '删除',
+ preview: '查看图片',
+ continue: '继续上传'
+ },
+ table: {
+ emptyText: '暂无数据',
+ confirmFilter: '筛选',
+ resetFilter: '重置',
+ clearFilter: '全部',
+ sumText: '合计'
+ },
+ tree: {
+ emptyText: '暂无数据'
+ },
+ transfer: {
+ noMatch: '无匹配数据',
+ noData: '无数据',
+ titles: ['列表 1', '列表 2'],
+ filterPlaceholder: '请输入搜索内容',
+ noCheckedFormat: '共 {total} 项',
+ hasCheckedFormat: '已选 {checked}/{total} 项'
+ }
+ }
+};
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+/***/ }),
+/* 46 */
+/***/ (function(module, exports, __webpack_require__) {
- /* istanbul ignore next */
- _checkbox2.default.install = function (Vue) {
- Vue.component(_checkbox2.default.name, _checkbox2.default);
- };
+"use strict";
- exports.default = _checkbox2.default;
-/***/ },
+var index$2 = function isMergeableObject(value) {
+ return isNonNullObject(value) && isNotSpecial(value)
+};
-/***/ 66:
-/***/ function(module, exports, __webpack_require__) {
+function isNonNullObject(value) {
+ return !!value && typeof value === 'object'
+}
- var Component = __webpack_require__(3)(
- /* script */
- __webpack_require__(67),
- /* template */
- __webpack_require__(68),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+function isNotSpecial(value) {
+ var stringValue = Object.prototype.toString.call(value);
- module.exports = Component.exports
+ return stringValue !== '[object RegExp]'
+ && stringValue !== '[object Date]'
+}
+function emptyTarget(val) {
+ return Array.isArray(val) ? [] : {}
+}
-/***/ },
+function cloneIfNecessary(value, optionsArgument) {
+ var clone = optionsArgument && optionsArgument.clone === true;
+ return (clone && index$2(value)) ? deepmerge(emptyTarget(value), value, optionsArgument) : value
+}
-/***/ 67:
-/***/ function(module, exports, __webpack_require__) {
+function defaultArrayMerge(target, source, optionsArgument) {
+ var destination = target.slice();
+ source.forEach(function(e, i) {
+ if (typeof destination[i] === 'undefined') {
+ destination[i] = cloneIfNecessary(e, optionsArgument);
+ } else if (index$2(e)) {
+ destination[i] = deepmerge(target[i], e, optionsArgument);
+ } else if (target.indexOf(e) === -1) {
+ destination.push(cloneIfNecessary(e, optionsArgument));
+ }
+ });
+ return destination
+}
- 'use strict';
+function mergeObject(target, source, optionsArgument) {
+ var destination = {};
+ if (index$2(target)) {
+ Object.keys(target).forEach(function(key) {
+ destination[key] = cloneIfNecessary(target[key], optionsArgument);
+ });
+ }
+ Object.keys(source).forEach(function(key) {
+ if (!index$2(source[key]) || !target[key]) {
+ destination[key] = cloneIfNecessary(source[key], optionsArgument);
+ } else {
+ destination[key] = deepmerge(target[key], source[key], optionsArgument);
+ }
+ });
+ return destination
+}
- exports.__esModule = true;
+function deepmerge(target, source, optionsArgument) {
+ var sourceIsArray = Array.isArray(source);
+ var targetIsArray = Array.isArray(target);
+ var options = optionsArgument || { arrayMerge: defaultArrayMerge };
+ var sourceAndTargetTypesMatch = sourceIsArray === targetIsArray;
- var _emitter = __webpack_require__(14);
+ if (!sourceAndTargetTypesMatch) {
+ return cloneIfNecessary(source, optionsArgument)
+ } else if (sourceIsArray) {
+ var arrayMerge = options.arrayMerge || defaultArrayMerge;
+ return arrayMerge(target, source, optionsArgument)
+ } else {
+ return mergeObject(target, source, optionsArgument)
+ }
+}
- var _emitter2 = _interopRequireDefault(_emitter);
+deepmerge.all = function deepmergeAll(array, optionsArgument) {
+ if (!Array.isArray(array) || array.length < 2) {
+ throw new Error('first argument should be an array with at least two elements')
+ }
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ // we are sure there are at least 2 values, so it is safe to have no initial value
+ return array.reduce(function(prev, next) {
+ return deepmerge(prev, next, optionsArgument)
+ })
+};
- exports.default = {
- name: 'ElCheckbox',
+var index = deepmerge;
- mixins: [_emitter2.default],
+module.exports = index;
- componentName: 'ElCheckbox',
- data: function data() {
- return {
- selfModel: false,
- focus: false
- };
- },
+/***/ }),
+/* 47 */
+/***/ (function(module, exports, __webpack_require__) {
+"use strict";
- computed: {
- model: {
- get: function get() {
- return this.isGroup ? this.store : this.value !== undefined ? this.value : this.selfModel;
- },
- set: function set(val) {
- if (this.isGroup) {
- var isLimitExceeded = false;
- this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (isLimitExceeded = true);
- this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (isLimitExceeded = true);
+exports.__esModule = true;
- isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]);
- } else {
- this.$emit('input', val);
- this.selfModel = val;
- }
- }
- },
+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; };
- 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;
- }
- },
+exports.default = function (Vue) {
- props: {
- value: {},
- label: {},
- indeterminate: Boolean,
- disabled: Boolean,
- checked: Boolean,
- name: String,
- trueLabel: [String, Number],
- falseLabel: [String, Number]
- },
+ /**
+ * template
+ *
+ * @param {String} string
+ * @param {Array} ...args
+ * @return {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;
+ function template(string) {
+ for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
+ args[_key - 1] = arguments[_key];
+ }
- this.$emit('change', ev);
- if (this.isGroup) {
- this.$nextTick(function (_) {
- _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]);
- });
- }
- }
- },
+ if (args.length === 1 && _typeof(args[0]) === 'object') {
+ args = args[0];
+ }
- created: function created() {
- this.checked && this.addToStore();
- }
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ if (!args || !args.hasOwnProperty) {
+ args = {};
+ }
-/***/ },
+ return string.replace(RE_NARGS, function (match, prefix, i, index) {
+ var result = void 0;
-/***/ 68:
-/***/ function(module, exports) {
+ if (string[index - 1] === '{' && string[index + match.length] === '}') {
+ return i;
+ } else {
+ result = (0, _util.hasOwn)(args, i) ? args[i] : null;
+ if (result === null || result === undefined) {
+ return '';
+ }
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('label', {
- staticClass: "el-checkbox"
- }, [_c('span', {
- staticClass: "el-checkbox__input",
- class: {
- 'is-disabled': _vm.disabled,
- 'is-checked': _vm.isChecked,
- 'is-indeterminate': _vm.indeterminate,
- 'is-focus': _vm.focus
- }
- }, [_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",
- "name": _vm.name,
- "disabled": _vm.disabled,
- "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": _vm.handleChange,
- "focus": function($event) {
- _vm.focus = true
- },
- "blur": function($event) {
- _vm.focus = false
- },
- "__c": 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 ($$c) {
- $$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
- }
- }
- }
- }) : _c('input', {
- directives: [{
- name: "model",
- rawName: "v-model",
- value: (_vm.model),
- expression: "model"
- }],
- staticClass: "el-checkbox__original",
- attrs: {
- "type": "checkbox",
- "disabled": _vm.disabled,
- "name": _vm.name
- },
- domProps: {
- "value": _vm.label,
- "checked": Array.isArray(_vm.model) ? _vm._i(_vm.model, _vm.label) > -1 : (_vm.model)
- },
- on: {
- "change": _vm.handleChange,
- "focus": function($event) {
- _vm.focus = true
- },
- "blur": function($event) {
- _vm.focus = false
- },
- "__c": 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 ($$c) {
- $$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.$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()])
- },staticRenderFns: []}
+ return result;
+ }
+ });
+ }
-/***/ }
+ return template;
+};
-/******/ });
+var _util = __webpack_require__(6);
+
+var RE_NARGS = /(%|)\{([0-9a-zA-Z_]+)\}/g;
+/**
+ * String format template
+ * - Inspired:
+ * https://github.com/Matt-Esch/string-template/index.js
+ */
/***/ }),
-/* 52 */
+/* 48 */
/***/ (function(module, exports, __webpack_require__) {
module.exports =
@@ -66667,241 +66619,368 @@ module.exports =
/***/ 0:
/***/ function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(345);
+ module.exports = __webpack_require__(216);
/***/ },
-/***/ 13:
+/***/ 3:
/***/ function(module, exports) {
- module.exports = __webpack_require__(13);
+ /* globals __VUE_SSR_CONTEXT__ */
-/***/ },
+ // this module is a runtime utility for cleaner component module output and will
+ // be included in the final webpack user bundle
-/***/ 55:
-/***/ function(module, exports) {
+ module.exports = function normalizeComponent (
+ rawScriptExports,
+ compiledTemplate,
+ injectStyles,
+ scopeId,
+ moduleIdentifier /* server only */
+ ) {
+ var esModule
+ var scriptExports = rawScriptExports = rawScriptExports || {}
- module.exports = __webpack_require__(3);
+ // ES6 modules interop
+ var type = typeof rawScriptExports.default
+ if (type === 'object' || type === 'function') {
+ esModule = rawScriptExports
+ scriptExports = rawScriptExports.default
+ }
-/***/ },
+ // Vue.extend constructor export interop
+ var options = typeof scriptExports === 'function'
+ ? scriptExports.options
+ : scriptExports
-/***/ 63:
-/***/ function(module, exports) {
+ // render functions
+ if (compiledTemplate) {
+ options.render = compiledTemplate.render
+ options.staticRenderFns = compiledTemplate.staticRenderFns
+ }
+
+ // scopedId
+ if (scopeId) {
+ options._scopeId = scopeId
+ }
+
+ var hook
+ if (moduleIdentifier) { // server build
+ hook = function (context) {
+ // 2.3 injection
+ context = context || (this.$vnode && this.$vnode.ssrContext)
+ // 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 = injectStyles
+ }
+
+ if (hook) {
+ // inject component registration as beforeCreate hook
+ var existing = options.beforeCreate
+ options.beforeCreate = existing
+ ? [].concat(existing, hook)
+ : [hook]
+ }
+
+ return {
+ esModule: esModule,
+ exports: scriptExports,
+ options: options
+ }
+ }
- module.exports = __webpack_require__(9);
/***/ },
-/***/ 197:
+/***/ 14:
/***/ function(module, exports) {
- module.exports = __webpack_require__(27);
+ module.exports = __webpack_require__(5);
/***/ },
-/***/ 345:
+/***/ 216:
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _main = __webpack_require__(346);
+ var _option = __webpack_require__(217);
- var _main2 = _interopRequireDefault(_main);
+ var _option2 = _interopRequireDefault(_option);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _main2.default.install = function (Vue) {
- Vue.component(_main2.default.name, _main2.default);
+ _option2.default.install = function (Vue) {
+ Vue.component(_option2.default.name, _option2.default);
};
- exports.default = _main2.default;
+ exports.default = _option2.default;
/***/ },
-/***/ 346:
+/***/ 217:
/***/ function(module, exports, __webpack_require__) {
- 'use strict';
+ var Component = __webpack_require__(3)(
+ /* script */
+ __webpack_require__(218),
+ /* template */
+ __webpack_require__(220),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
- exports.__esModule = true;
+ module.exports = Component.exports
- var _vuePopper = __webpack_require__(13);
- var _vuePopper2 = _interopRequireDefault(_vuePopper);
+/***/ },
- var _debounce = __webpack_require__(63);
+/***/ 218:
+/***/ function(module, exports, __webpack_require__) {
- var _debounce2 = _interopRequireDefault(_debounce);
+ 'use strict';
- var _vdom = __webpack_require__(197);
+ exports.__esModule = true;
- var _vue = __webpack_require__(55);
+ 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; }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
- var _vue2 = _interopRequireDefault(_vue);
+ var _emitter = __webpack_require__(14);
+
+ var _emitter2 = _interopRequireDefault(_emitter);
+
+ var _util = __webpack_require__(219);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElTooltip',
+ mixins: [_emitter2.default],
- mixins: [_vuePopper2.default],
+ name: 'ElOption',
+
+ componentName: 'ElOption',
props: {
- openDelay: {
- type: Number,
- default: 0
+ value: {
+ required: true
},
- disabled: Boolean,
- manual: Boolean,
- effect: {
- type: String,
- default: 'dark'
+ label: [String, Number],
+ created: Boolean,
+ disabled: {
+ type: Boolean,
+ default: false
+ }
+ },
+
+ data: function data() {
+ return {
+ index: -1,
+ groupDisabled: false,
+ visible: true,
+ hitState: false
+ };
+ },
+
+
+ computed: {
+ isObject: function isObject() {
+ return Object.prototype.toString.call(this.value).toLowerCase() === '[object object]';
},
- popperClass: String,
- content: String,
- visibleArrow: {
- default: true
+ currentLabel: function currentLabel() {
+ return this.label || (this.isObject ? '' : this.value);
},
- transition: {
- type: String,
- default: 'el-fade-in-linear'
+ currentValue: function currentValue() {
+ return this.value || this.label || '';
},
- popperOptions: {
- default: function _default() {
- return {
- boundariesPadding: 10,
- gpuAcceleration: false
- };
+ parent: function parent() {
+ var result = this.$parent;
+ while (!result.isSelect) {
+ result = result.$parent;
}
+ return result;
},
- enterable: {
- type: Boolean,
- default: true
+ itemSelected: function itemSelected() {
+ if (!this.parent.multiple) {
+ return this.isEqual(this.value, this.parent.value);
+ } else {
+ return this.contains(this.parent.value, this.value);
+ }
+ },
+ limitReached: function limitReached() {
+ if (this.parent.multiple) {
+ return !this.itemSelected && this.parent.value.length >= this.parent.multipleLimit && this.parent.multipleLimit > 0;
+ } else {
+ return false;
+ }
}
},
- beforeCreate: function beforeCreate() {
- var _this = this;
-
- if (this.$isServer) return;
+ watch: {
+ currentLabel: function currentLabel() {
+ if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
+ },
+ value: function value() {
+ if (!this.created && !this.parent.remote) this.dispatch('ElSelect', 'setSelected');
+ }
+ },
- this.popperVM = new _vue2.default({
- data: { node: '' },
- render: function render(h) {
- return this.node;
+ methods: {
+ isEqual: function isEqual(a, b) {
+ if (!this.isObject) {
+ return a === b;
+ } else {
+ var valueKey = this.parent.valueKey;
+ return (0, _util.getValueByPath)(a, valueKey) === (0, _util.getValueByPath)(b, valueKey);
}
- }).$mount();
+ },
+ contains: function contains() {
+ var _this = this;
- this.debounceClose = (0, _debounce2.default)(200, function () {
- return _this.handleClosePopper();
- });
- },
- render: function render(h) {
- var _this2 = this;
+ var arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
+ var target = arguments[1];
- 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);
- }
- },
+ if (!this.isObject) {
+ return arr.indexOf(target) > -1;
+ } else {
+ var _ret = function () {
+ var valueKey = _this.parent.valueKey;
+ return {
+ v: arr.some(function (item) {
+ return (0, _util.getValueByPath)(item, valueKey) === (0, _util.getValueByPath)(target, valueKey);
+ })
+ };
+ }();
- ref: 'popper',
- directives: [{
- name: 'show',
- value: !this.disabled && this.showPopper
- }],
+ if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
+ }
+ },
+ handleGroupDisabled: function handleGroupDisabled(val) {
+ this.groupDisabled = val;
+ },
+ hoverItem: function hoverItem() {
+ if (!this.disabled && !this.groupDisabled) {
+ this.parent.hoverIndex = this.parent.options.indexOf(this);
+ }
+ },
+ selectOptionClick: function selectOptionClick() {
+ if (this.disabled !== true && this.groupDisabled !== true) {
+ this.dispatch('ElSelect', 'handleOptionClick', this);
+ }
+ },
+ queryChange: function queryChange(query) {
+ // query 里如果有正则中的特殊字符,需要先将这些字符转义
+ var parsedQuery = String(query).replace(/(\^|\(|\)|\[|\]|\$|\*|\+|\.|\?|\\|\{|\}|\|)/g, '\\$1');
+ this.visible = new RegExp(parsedQuery, 'i').test(this.currentLabel) || this.created;
+ if (!this.visible) {
+ this.parent.filteredOptionsCount--;
+ }
+ },
+ resetIndex: function resetIndex() {
+ var _this2 = this;
- 'class': ['el-tooltip__popper', 'is-' + this.effect, this.popperClass] },
- [this.$slots.content || this.content]
- )]
- );
+ this.$nextTick(function () {
+ _this2.index = _this2.parent.options.indexOf(_this2);
+ });
}
+ },
- if (!this.$slots.default || !this.$slots.default.length) return this.$slots.default;
+ created: function created() {
+ this.parent.options.push(this);
+ this.parent.cachedOptions.push(this);
+ this.parent.optionsCount++;
+ this.parent.filteredOptionsCount++;
+ this.index = this.parent.options.indexOf(this);
- var vnode = (0, _vdom.getFirstComponentChild)(this.$slots.default);
- if (!vnode) return vnode;
- var data = vnode.data = vnode.data || {};
- var on = vnode.data.on = vnode.data.on || {};
- var nativeOn = vnode.data.nativeOn = vnode.data.nativeOn || {};
+ this.$on('queryChange', this.queryChange);
+ this.$on('handleGroupDisabled', this.handleGroupDisabled);
+ this.$on('resetIndex', this.resetIndex);
+ },
+ beforeDestroy: function beforeDestroy() {
+ this.dispatch('ElSelect', 'onOptionDestroy', this);
+ }
+ };
- on.mouseenter = this.addEventHandle(on.mouseenter, function () {
- _this2.setExpectedState(true);_this2.handleShowPopper();
- });
- on.mouseleave = this.addEventHandle(on.mouseleave, function () {
- _this2.setExpectedState(false);_this2.debounceClose();
- });
- nativeOn.mouseenter = this.addEventHandle(nativeOn.mouseenter, function () {
- _this2.setExpectedState(true);_this2.handleShowPopper();
- });
- nativeOn.mouseleave = this.addEventHandle(nativeOn.mouseleave, function () {
- _this2.setExpectedState(false);_this2.debounceClose();
- });
- data.staticClass = this.concatClass(data.staticClass, 'el-tooltip');
+/***/ },
- return vnode;
- },
- mounted: function mounted() {
- this.referenceElm = this.$el;
- },
+/***/ 219:
+/***/ function(module, exports) {
+ module.exports = __webpack_require__(6);
- methods: {
- addEventHandle: function addEventHandle(old, fn) {
- return old ? Array.isArray(old) ? old.concat(fn) : [old, fn] : fn;
- },
- concatClass: function concatClass(a, b) {
- if (a && a.indexOf(b) > -1) return a;
- return a ? b ? a + ' ' + b : a : b || '';
- },
- handleShowPopper: function handleShowPopper() {
- var _this3 = this;
+/***/ },
- if (!this.expectedState || this.manual) return;
- clearTimeout(this.timeout);
- this.timeout = setTimeout(function () {
- _this3.showPopper = true;
- }, this.openDelay);
- },
- handleClosePopper: function handleClosePopper() {
- if (this.enterable && this.expectedState || this.manual) return;
- clearTimeout(this.timeout);
- this.showPopper = false;
+/***/ 220:
+/***/ function(module, exports) {
+
+ module.exports={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.parent.hoverIndex === _vm.index
},
- setExpectedState: function setExpectedState(expectedState) {
- this.expectedState = expectedState;
+ on: {
+ "mouseenter": _vm.hoverItem,
+ "click": function($event) {
+ $event.stopPropagation();
+ _vm.selectOptionClick($event)
+ }
}
- }
- };
+ }, [_vm._t("default", [_c('span', [_vm._v(_vm._s(_vm.currentLabel))])])], 2)
+ },staticRenderFns: []}
/***/ }
/******/ });
/***/ }),
-/* 53 */
-/***/ (function(module, exports, __webpack_require__) {
+/* 49 */
+/***/ (function(module, exports) {
module.exports =
/******/ (function(modules) { // webpackBootstrap
@@ -66951,7 +67030,7 @@ module.exports =
/***/ 0:
/***/ function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(73);
+ module.exports = __webpack_require__(30);
/***/ },
@@ -66989,1782 +67068,1264 @@ module.exports =
// render functions
if (compiledTemplate) {
options.render = compiledTemplate.render
- options.staticRenderFns = compiledTemplate.staticRenderFns
- }
-
- // scopedId
- if (scopeId) {
- options._scopeId = scopeId
- }
-
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context = context || (this.$vnode && this.$vnode.ssrContext)
- // 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 = injectStyles
- }
-
- if (hook) {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
-
- return {
- esModule: esModule,
- exports: scriptExports,
- options: options
- }
- }
-
-
-/***/ },
-
-/***/ 14:
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(5);
-
-/***/ },
-
-/***/ 73:
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _checkboxGroup = __webpack_require__(74);
-
- var _checkboxGroup2 = _interopRequireDefault(_checkboxGroup);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- /* istanbul ignore next */
- _checkboxGroup2.default.install = function (Vue) {
- Vue.component(_checkboxGroup2.default.name, _checkboxGroup2.default);
- };
-
- exports.default = _checkboxGroup2.default;
-
-/***/ },
-
-/***/ 74:
-/***/ function(module, exports, __webpack_require__) {
-
- var Component = __webpack_require__(3)(
- /* script */
- __webpack_require__(75),
- /* template */
- __webpack_require__(76),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
-
- module.exports = Component.exports
-
-
-/***/ },
-
-/***/ 75:
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _emitter = __webpack_require__(14);
-
- var _emitter2 = _interopRequireDefault(_emitter);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = {
- name: 'ElCheckboxGroup',
-
- componentName: 'ElCheckboxGroup',
-
- mixins: [_emitter2.default],
-
- props: {
- value: {},
- min: Number,
- max: Number,
- size: String,
- fill: String,
- textColor: String
- },
-
- watch: {
- value: function value(_value) {
- this.dispatch('ElFormItem', 'el.form.change', [_value]);
- }
- }
- };
-
-/***/ },
-
-/***/ 76:
-/***/ function(module, exports) {
-
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-checkbox-group"
- }, [_vm._t("default")], 2)
- },staticRenderFns: []}
-
-/***/ }
-
-/******/ });
-
-/***/ }),
-/* 54 */
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-var __WEBPACK_AMD_DEFINE_RESULT__;
-
-/* Modified from https://github.com/taylorhakes/fecha
- *
- * The MIT License (MIT)
- *
- * Copyright (c) 2015 Taylor Hakes
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- */
-
-/*eslint-disable*/
-// 把 YYYY-MM-DD 改成了 yyyy-MM-dd
-(function (main) {
- 'use strict';
-
- /**
- * Parse or format dates
- * @class fecha
- */
-
- var fecha = {};
- var token = /d{1,4}|M{1,4}|yy(?:yy)?|S{1,3}|Do|ZZ|([HhMsDm])\1?|[aA]|"[^"]*"|'[^']*'/g;
- var twoDigits = /\d\d?/;
- var threeDigits = /\d{3}/;
- var fourDigits = /\d{4}/;
- var word = /[0-9]*['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+|[\u0600-\u06FF\/]+(\s*?[\u0600-\u06FF]+){1,2}/i;
- var noop = function noop() {};
-
- function shorten(arr, sLen) {
- var newArr = [];
- for (var i = 0, len = arr.length; i < len; i++) {
- newArr.push(arr[i].substr(0, sLen));
- }
- return newArr;
- }
-
- function monthUpdate(arrName) {
- return function (d, v, i18n) {
- var index = i18n[arrName].indexOf(v.charAt(0).toUpperCase() + v.substr(1).toLowerCase());
- if (~index) {
- d.month = index;
- }
- };
- }
-
- function pad(val, len) {
- val = String(val);
- len = len || 2;
- while (val.length < len) {
- val = '0' + val;
- }
- return val;
- }
-
- var dayNames = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
- var monthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];
- var monthNamesShort = shorten(monthNames, 3);
- var dayNamesShort = shorten(dayNames, 3);
- fecha.i18n = {
- dayNamesShort: dayNamesShort,
- dayNames: dayNames,
- monthNamesShort: monthNamesShort,
- monthNames: monthNames,
- amPm: ['am', 'pm'],
- DoFn: function DoFn(D) {
- return D + ['th', 'st', 'nd', 'rd'][D % 10 > 3 ? 0 : (D - D % 10 !== 10) * D % 10];
- }
- };
-
- var formatFlags = {
- D: function D(dateObj) {
- return dateObj.getDay();
- },
- DD: function DD(dateObj) {
- return pad(dateObj.getDay());
- },
- Do: function Do(dateObj, i18n) {
- return i18n.DoFn(dateObj.getDate());
- },
- d: function d(dateObj) {
- return dateObj.getDate();
- },
- dd: function dd(dateObj) {
- return pad(dateObj.getDate());
- },
- ddd: function ddd(dateObj, i18n) {
- return i18n.dayNamesShort[dateObj.getDay()];
- },
- dddd: function dddd(dateObj, i18n) {
- return i18n.dayNames[dateObj.getDay()];
- },
- M: function M(dateObj) {
- return dateObj.getMonth() + 1;
- },
- MM: function MM(dateObj) {
- return pad(dateObj.getMonth() + 1);
- },
- MMM: function MMM(dateObj, i18n) {
- return i18n.monthNamesShort[dateObj.getMonth()];
- },
- MMMM: function MMMM(dateObj, i18n) {
- return i18n.monthNames[dateObj.getMonth()];
- },
- yy: function yy(dateObj) {
- return String(dateObj.getFullYear()).substr(2);
- },
- yyyy: function yyyy(dateObj) {
- return dateObj.getFullYear();
- },
- h: function h(dateObj) {
- return dateObj.getHours() % 12 || 12;
- },
- hh: function hh(dateObj) {
- return pad(dateObj.getHours() % 12 || 12);
- },
- H: function H(dateObj) {
- return dateObj.getHours();
- },
- HH: function HH(dateObj) {
- return pad(dateObj.getHours());
- },
- m: function m(dateObj) {
- return dateObj.getMinutes();
- },
- mm: function mm(dateObj) {
- return pad(dateObj.getMinutes());
- },
- s: function s(dateObj) {
- return dateObj.getSeconds();
- },
- ss: function ss(dateObj) {
- return pad(dateObj.getSeconds());
- },
- S: function S(dateObj) {
- return Math.round(dateObj.getMilliseconds() / 100);
- },
- SS: function SS(dateObj) {
- return pad(Math.round(dateObj.getMilliseconds() / 10), 2);
- },
- SSS: function SSS(dateObj) {
- return pad(dateObj.getMilliseconds(), 3);
- },
- a: function a(dateObj, i18n) {
- return dateObj.getHours() < 12 ? i18n.amPm[0] : i18n.amPm[1];
- },
- A: function A(dateObj, i18n) {
- return dateObj.getHours() < 12 ? i18n.amPm[0].toUpperCase() : i18n.amPm[1].toUpperCase();
- },
- ZZ: function ZZ(dateObj) {
- var o = dateObj.getTimezoneOffset();
- return (o > 0 ? '-' : '+') + pad(Math.floor(Math.abs(o) / 60) * 100 + Math.abs(o) % 60, 4);
- }
- };
-
- var parseFlags = {
- d: [twoDigits, function (d, v) {
- d.day = v;
- }],
- M: [twoDigits, function (d, v) {
- d.month = v - 1;
- }],
- yy: [twoDigits, function (d, v) {
- var da = new Date(),
- cent = +('' + da.getFullYear()).substr(0, 2);
- d.year = '' + (v > 68 ? cent - 1 : cent) + v;
- }],
- h: [twoDigits, function (d, v) {
- d.hour = v;
- }],
- m: [twoDigits, function (d, v) {
- d.minute = v;
- }],
- s: [twoDigits, function (d, v) {
- d.second = v;
- }],
- yyyy: [fourDigits, function (d, v) {
- d.year = v;
- }],
- S: [/\d/, function (d, v) {
- d.millisecond = v * 100;
- }],
- SS: [/\d{2}/, function (d, v) {
- d.millisecond = v * 10;
- }],
- SSS: [threeDigits, function (d, v) {
- d.millisecond = v;
- }],
- D: [twoDigits, noop],
- ddd: [word, noop],
- MMM: [word, monthUpdate('monthNamesShort')],
- MMMM: [word, monthUpdate('monthNames')],
- a: [word, function (d, v, i18n) {
- var val = v.toLowerCase();
- if (val === i18n.amPm[0]) {
- d.isPm = false;
- } else if (val === i18n.amPm[1]) {
- d.isPm = true;
- }
- }],
- ZZ: [/[\+\-]\d\d:?\d\d/, function (d, v) {
- var parts = (v + '').match(/([\+\-]|\d\d)/gi),
- minutes;
-
- if (parts) {
- minutes = +(parts[1] * 60) + parseInt(parts[2], 10);
- d.timezoneOffset = parts[0] === '+' ? minutes : -minutes;
- }
- }]
- };
- parseFlags.DD = parseFlags.D;
- parseFlags.dddd = parseFlags.ddd;
- parseFlags.Do = parseFlags.dd = parseFlags.d;
- parseFlags.mm = parseFlags.m;
- parseFlags.hh = parseFlags.H = parseFlags.HH = parseFlags.h;
- parseFlags.MM = parseFlags.M;
- parseFlags.ss = parseFlags.s;
- parseFlags.A = parseFlags.a;
-
- // Some common format strings
- fecha.masks = {
- 'default': 'ddd MMM dd yyyy HH:mm:ss',
- shortDate: 'M/D/yy',
- mediumDate: 'MMM d, yyyy',
- longDate: 'MMMM d, yyyy',
- fullDate: 'dddd, MMMM d, yyyy',
- shortTime: 'HH:mm',
- mediumTime: 'HH:mm:ss',
- longTime: 'HH:mm:ss.SSS'
- };
-
- /***
- * Format a date
- * @method format
- * @param {Date|number} dateObj
- * @param {string} mask Format of the date, i.e. 'mm-dd-yy' or 'shortDate'
- */
- fecha.format = function (dateObj, mask, i18nSettings) {
- var i18n = i18nSettings || fecha.i18n;
+ options.staticRenderFns = compiledTemplate.staticRenderFns
+ }
- if (typeof dateObj === 'number') {
- dateObj = new Date(dateObj);
- }
+ // scopedId
+ if (scopeId) {
+ options._scopeId = scopeId
+ }
- if (Object.prototype.toString.call(dateObj) !== '[object Date]' || isNaN(dateObj.getTime())) {
- throw new Error('Invalid Date in fecha.format');
- }
+ var hook
+ if (moduleIdentifier) { // server build
+ hook = function (context) {
+ // 2.3 injection
+ context = context || (this.$vnode && this.$vnode.ssrContext)
+ // 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 = injectStyles
+ }
- mask = fecha.masks[mask] || mask || fecha.masks['default'];
+ if (hook) {
+ // inject component registration as beforeCreate hook
+ var existing = options.beforeCreate
+ options.beforeCreate = existing
+ ? [].concat(existing, hook)
+ : [hook]
+ }
- return mask.replace(token, function ($0) {
- return $0 in formatFlags ? formatFlags[$0](dateObj, i18n) : $0.slice(1, $0.length - 1);
- });
- };
+ return {
+ esModule: esModule,
+ exports: scriptExports,
+ options: options
+ }
+ }
- /**
- * Parse a date string into an object, changes - into /
- * @method parse
- * @param {string} dateStr Date string
- * @param {string} format Date parse format
- * @returns {Date|boolean}
- */
- fecha.parse = function (dateStr, format, i18nSettings) {
- var i18n = i18nSettings || fecha.i18n;
- if (typeof format !== 'string') {
- throw new Error('Invalid format in fecha.parse');
- }
+/***/ },
- format = fecha.masks[format] || format;
+/***/ 30:
+/***/ function(module, exports, __webpack_require__) {
- // Avoid regular expression denial of service, fail early for really long strings
- // https://www.owasp.org/index.php/Regular_expression_Denial_of_Service_-_ReDoS
- if (dateStr.length > 1000) {
- return false;
- }
+ 'use strict';
- var isValid = true;
- var dateInfo = {};
- format.replace(token, function ($0) {
- if (parseFlags[$0]) {
- var info = parseFlags[$0];
- var index = dateStr.search(info[0]);
- if (!~index) {
- isValid = false;
- } else {
- dateStr.replace(info[0], function (result) {
- info[1](dateInfo, result, i18n);
- dateStr = dateStr.substr(index + result.length);
- return result;
- });
- }
- }
+ exports.__esModule = true;
- return parseFlags[$0] ? '' : $0.slice(1, $0.length - 1);
- });
+ var _button = __webpack_require__(31);
- if (!isValid) {
- return false;
- }
+ var _button2 = _interopRequireDefault(_button);
- var today = new Date();
- if (dateInfo.isPm === true && dateInfo.hour != null && +dateInfo.hour !== 12) {
- dateInfo.hour = +dateInfo.hour + 12;
- } else if (dateInfo.isPm === false && +dateInfo.hour === 12) {
- dateInfo.hour = 0;
- }
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var date;
- if (dateInfo.timezoneOffset != null) {
- dateInfo.minute = +(dateInfo.minute || 0) - +dateInfo.timezoneOffset;
- date = new Date(Date.UTC(dateInfo.year || today.getFullYear(), dateInfo.month || 0, dateInfo.day || 1, dateInfo.hour || 0, dateInfo.minute || 0, dateInfo.second || 0, dateInfo.millisecond || 0));
- } else {
- date = new Date(dateInfo.year || today.getFullYear(), dateInfo.month || 0, dateInfo.day || 1, dateInfo.hour || 0, dateInfo.minute || 0, dateInfo.second || 0, dateInfo.millisecond || 0);
- }
- return date;
- };
+ /* istanbul ignore next */
+ _button2.default.install = function (Vue) {
+ Vue.component(_button2.default.name, _button2.default);
+ };
- /* istanbul ignore next */
- if (typeof module !== 'undefined' && module.exports) {
- module.exports = fecha;
- } else if (true) {
- !(__WEBPACK_AMD_DEFINE_RESULT__ = function () {
- return fecha;
- }.call(exports, __webpack_require__, exports, module),
- __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
- } else {
- main.fecha = fecha;
- }
-})(undefined);
+ exports.default = _button2.default;
-/***/ }),
-/* 55 */
-/***/ (function(module, exports, __webpack_require__) {
+/***/ },
-"use strict";
+/***/ 31:
+/***/ function(module, exports, __webpack_require__) {
+ var Component = __webpack_require__(3)(
+ /* script */
+ __webpack_require__(32),
+ /* template */
+ __webpack_require__(33),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+ module.exports = Component.exports
-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; };
-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; };
+/***/ },
-var _util = __webpack_require__(0);
+/***/ 32:
+/***/ function(module, exports) {
-var _validator = __webpack_require__(56);
+ 'use strict';
-var _validator2 = _interopRequireDefault(_validator);
+ exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
-var _messages2 = __webpack_require__(75);
+ exports.default = {
+ name: 'ElButton',
-var _rule = __webpack_require__(1);
+ 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
+ },
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+ methods: {
+ handleClick: function handleClick(evt) {
+ this.$emit('click', evt);
+ },
+ handleInnerClick: function handleInnerClick(evt) {
+ if (this.disabled) {
+ evt.stopPropagation();
+ }
+ }
+ }
+ };
-/**
- * Encapsulates a validation schema.
- *
- * @param descriptor An object declaring validation rules
- * for this schema.
- */
-function Schema(descriptor) {
- this.rules = null;
- this._messages = _messages2.messages;
- this.define(descriptor);
-}
+/***/ },
-Schema.prototype = {
- messages: function messages(_messages) {
- if (_messages) {
- this._messages = (0, _util.deepMerge)((0, _messages2.newMessages)(), _messages);
- }
- return this._messages;
- },
- define: function define(rules) {
- if (!rules) {
- throw new Error('Cannot configure a schema with no rules');
- }
- if ((typeof rules === 'undefined' ? 'undefined' : _typeof(rules)) !== 'object' || Array.isArray(rules)) {
- throw new Error('Rules must be an object');
- }
- this.rules = {};
- var z = void 0;
- var item = void 0;
- for (z in rules) {
- if (rules.hasOwnProperty(z)) {
- item = rules[z];
- this.rules[z] = Array.isArray(item) ? item : [item];
- }
- }
- },
- validate: function validate(source_) {
- var _this = this;
+/***/ 33:
+/***/ function(module, exports) {
- var o = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
- var oc = arguments[2];
+ module.exports={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.size ? 'el-button--' + _vm.size : '', {
+ 'is-disabled': _vm.disabled,
+ 'is-loading': _vm.loading,
+ 'is-plain': _vm.plain
+ }
+ ],
+ attrs: {
+ "disabled": _vm.disabled,
+ "autofocus": _vm.autofocus,
+ "type": _vm.nativeType
+ },
+ on: {
+ "click": _vm.handleClick
+ }
+ }, [(_vm.loading) ? _c('i', {
+ staticClass: "el-icon-loading",
+ on: {
+ "click": _vm.handleInnerClick
+ }
+ }) : _vm._e(), (_vm.icon && !_vm.loading) ? _c('i', {
+ class: 'el-icon-' + _vm.icon,
+ on: {
+ "click": _vm.handleInnerClick
+ }
+ }) : _vm._e(), (_vm.$slots.default) ? _c('span', {
+ on: {
+ "click": _vm.handleInnerClick
+ }
+ }, [_vm._t("default")], 2) : _vm._e()])
+ },staticRenderFns: []}
- var source = source_;
- var options = o;
- var callback = oc;
- if (typeof options === 'function') {
- callback = options;
- options = {};
- }
- if (!this.rules || Object.keys(this.rules).length === 0) {
- if (callback) {
- callback();
- }
- return;
- }
- function complete(results) {
- var i = void 0;
- var field = void 0;
- var errors = [];
- var fields = {};
+/***/ }
- function add(e) {
- if (Array.isArray(e)) {
- errors = errors.concat.apply(errors, e);
- } else {
- errors.push(e);
- }
- }
+/******/ });
- for (i = 0; i < results.length; i++) {
- add(results[i]);
- }
- if (!errors.length) {
- errors = null;
- fields = null;
- } else {
- for (i = 0; i < errors.length; i++) {
- field = errors[i].field;
- fields[field] = fields[field] || [];
- fields[field].push(errors[i]);
- }
- }
- callback(errors, fields);
- }
+/***/ }),
+/* 50 */
+/***/ (function(module, exports) {
- if (options.messages) {
- var messages = this.messages();
- if (messages === _messages2.messages) {
- messages = (0, _messages2.newMessages)();
- }
- (0, _util.deepMerge)(messages, options.messages);
- options.messages = messages;
- } else {
- options.messages = this.messages();
- }
+module.exports =
+/******/ (function(modules) { // webpackBootstrap
+/******/ // The module cache
+/******/ var installedModules = {};
- options.error = _rule.error;
- var arr = void 0;
- var value = void 0;
- var series = {};
- var keys = options.keys || Object.keys(this.rules);
- keys.forEach(function (z) {
- arr = _this.rules[z];
- value = source[z];
- arr.forEach(function (r) {
- var rule = r;
- if (typeof rule.transform === 'function') {
- if (source === source_) {
- source = _extends({}, source);
- }
- value = source[z] = rule.transform(value);
- }
- if (typeof rule === 'function') {
- rule = {
- validator: rule
- };
- } else {
- rule = _extends({}, rule);
- }
- rule.validator = _this.getValidationMethod(rule);
- rule.field = z;
- rule.fullField = rule.fullField || z;
- rule.type = _this.getType(rule);
- if (!rule.validator) {
- return;
- }
- series[z] = series[z] || [];
- series[z].push({
- rule: rule,
- value: value,
- source: source,
- field: z
- });
- });
- });
- var errorFields = {};
- (0, _util.asyncMap)(series, options, function (data, doIt) {
- var rule = data.rule;
- var deep = (rule.type === 'object' || rule.type === 'array') && (_typeof(rule.fields) === 'object' || _typeof(rule.defaultField) === 'object');
- deep = deep && (rule.required || !rule.required && data.value);
- rule.field = data.field;
- function addFullfield(key, schema) {
- return _extends({}, schema, {
- fullField: rule.fullField + '.' + key
- });
- }
+/******/ // The require function
+/******/ function __webpack_require__(moduleId) {
- function cb() {
- var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
+/******/ // Check if module is in cache
+/******/ if(installedModules[moduleId])
+/******/ return installedModules[moduleId].exports;
- var errors = e;
- if (!Array.isArray(errors)) {
- errors = [errors];
- }
- if (errors.length) {
- (0, _util.warning)('async-validator:', errors);
- }
- if (errors.length && rule.message) {
- errors = [].concat(rule.message);
- }
+/******/ // Create a new module (and put it into the cache)
+/******/ var module = installedModules[moduleId] = {
+/******/ exports: {},
+/******/ id: moduleId,
+/******/ loaded: false
+/******/ };
- errors = errors.map((0, _util.complementError)(rule));
+/******/ // Execute the module function
+/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
- if ((options.first || options.fieldFirst) && errors.length) {
- errorFields[rule.field] = 1;
- return doIt(errors);
- }
- if (!deep) {
- doIt(errors);
- } else {
- // if rule is required but the target object
- // does not exist fail at the rule level and don't
- // go deeper
- if (rule.required && !data.value) {
- if (rule.message) {
- errors = [].concat(rule.message).map((0, _util.complementError)(rule));
- } else {
- errors = [options.error(rule, (0, _util.format)(options.messages.required, rule.field))];
- }
- return doIt(errors);
- }
+/******/ // Flag the module as loaded
+/******/ module.loaded = true;
- var fieldsSchema = {};
- if (rule.defaultField) {
- for (var k in data.value) {
- if (data.value.hasOwnProperty(k)) {
- fieldsSchema[k] = rule.defaultField;
- }
- }
- }
- fieldsSchema = _extends({}, fieldsSchema, data.rule.fields);
- for (var f in fieldsSchema) {
- if (fieldsSchema.hasOwnProperty(f)) {
- var fieldSchema = Array.isArray(fieldsSchema[f]) ? fieldsSchema[f] : [fieldsSchema[f]];
- fieldsSchema[f] = fieldSchema.map(addFullfield.bind(null, f));
- }
- }
- var schema = new Schema(fieldsSchema);
- schema.messages(options.messages);
- if (data.rule.options) {
- data.rule.options.messages = options.messages;
- data.rule.options.error = options.error;
- }
- schema.validate(data.value, data.rule.options || options, function (errs) {
- doIt(errs && errs.length ? errors.concat(errs) : errs);
- });
- }
- }
+/******/ // Return the exports of the module
+/******/ return module.exports;
+/******/ }
- rule.validator(rule, data.value, cb, data.source, options);
- }, function (results) {
- complete(results);
- });
- },
- getType: function getType(rule) {
- if (rule.type === undefined && rule.pattern instanceof RegExp) {
- rule.type = 'pattern';
- }
- if (typeof rule.validator !== 'function' && rule.type && !_validator2["default"].hasOwnProperty(rule.type)) {
- throw new Error((0, _util.format)('Unknown rule type %s', rule.type));
- }
- return rule.type || 'string';
- },
- getValidationMethod: function getValidationMethod(rule) {
- if (typeof rule.validator === 'function') {
- return rule.validator;
- }
- var keys = Object.keys(rule);
- var messageIndex = keys.indexOf('message');
- if (messageIndex !== -1) {
- keys.splice(messageIndex, 1);
- }
- if (keys.length === 1 && keys[0] === 'required') {
- return _validator2["default"].required;
- }
- return _validator2["default"][this.getType(rule)] || false;
- }
-};
-Schema.register = function register(type, validator) {
- if (typeof validator !== 'function') {
- throw new Error('Cannot register a validator by type, validator is not a function');
- }
- _validator2["default"][type] = validator;
-};
+/******/ // expose the modules object (__webpack_modules__)
+/******/ __webpack_require__.m = modules;
+
+/******/ // expose the module cache
+/******/ __webpack_require__.c = installedModules;
-Schema.messages = _messages2.messages;
+/******/ // __webpack_public_path__
+/******/ __webpack_require__.p = "/dist/";
-exports["default"] = Schema;
-module.exports = exports['default'];
+/******/ // Load entry module and return exports
+/******/ return __webpack_require__(0);
+/******/ })
+/************************************************************************/
+/******/ ({
-/***/ }),
-/* 56 */
-/***/ (function(module, exports, __webpack_require__) {
+/***/ 0:
+/***/ function(module, exports, __webpack_require__) {
-"use strict";
+ module.exports = __webpack_require__(34);
-module.exports = {
- string: __webpack_require__(57),
- method: __webpack_require__(63),
- number: __webpack_require__(64),
- "boolean": __webpack_require__(65),
- regexp: __webpack_require__(66),
- integer: __webpack_require__(67),
- "float": __webpack_require__(68),
- array: __webpack_require__(69),
- object: __webpack_require__(70),
- "enum": __webpack_require__(71),
- pattern: __webpack_require__(72),
- email: __webpack_require__(17),
- url: __webpack_require__(17),
- date: __webpack_require__(73),
- hex: __webpack_require__(17),
- required: __webpack_require__(74)
-};
+/***/ },
-/***/ }),
-/* 57 */
-/***/ (function(module, exports, __webpack_require__) {
+/***/ 3:
+/***/ function(module, exports) {
-"use strict";
+ /* globals __VUE_SSR_CONTEXT__ */
+ // this module is a runtime utility for cleaner component module output and will
+ // be included in the final webpack user bundle
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+ module.exports = function normalizeComponent (
+ rawScriptExports,
+ compiledTemplate,
+ injectStyles,
+ scopeId,
+ moduleIdentifier /* server only */
+ ) {
+ var esModule
+ var scriptExports = rawScriptExports = rawScriptExports || {}
-var _rule = __webpack_require__(1);
+ // ES6 modules interop
+ var type = typeof rawScriptExports.default
+ if (type === 'object' || type === 'function') {
+ esModule = rawScriptExports
+ scriptExports = rawScriptExports.default
+ }
-var _rule2 = _interopRequireDefault(_rule);
+ // Vue.extend constructor export interop
+ var options = typeof scriptExports === 'function'
+ ? scriptExports.options
+ : scriptExports
-var _util = __webpack_require__(0);
+ // render functions
+ if (compiledTemplate) {
+ options.render = compiledTemplate.render
+ options.staticRenderFns = compiledTemplate.staticRenderFns
+ }
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+ // scopedId
+ if (scopeId) {
+ options._scopeId = scopeId
+ }
-/**
- * Performs validation for string types.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function string(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value, 'string') && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options, 'string');
- if (!(0, _util.isEmptyValue)(value, 'string')) {
- _rule2["default"].type(rule, value, source, errors, options);
- _rule2["default"].range(rule, value, source, errors, options);
- _rule2["default"].pattern(rule, value, source, errors, options);
- if (rule.whitespace === true) {
- _rule2["default"].whitespace(rule, value, source, errors, options);
- }
- }
- }
- callback(errors);
-}
+ var hook
+ if (moduleIdentifier) { // server build
+ hook = function (context) {
+ // 2.3 injection
+ context = context || (this.$vnode && this.$vnode.ssrContext)
+ // 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 = injectStyles
+ }
-exports["default"] = string;
-module.exports = exports['default'];
+ if (hook) {
+ // inject component registration as beforeCreate hook
+ var existing = options.beforeCreate
+ options.beforeCreate = existing
+ ? [].concat(existing, hook)
+ : [hook]
+ }
-/***/ }),
-/* 58 */
-/***/ (function(module, exports, __webpack_require__) {
+ return {
+ esModule: esModule,
+ exports: scriptExports,
+ options: options
+ }
+ }
-"use strict";
+/***/ },
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+/***/ 34:
+/***/ function(module, exports, __webpack_require__) {
-var _util = __webpack_require__(0);
+ 'use strict';
-var util = _interopRequireWildcard(_util);
+ exports.__esModule = true;
-function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj["default"] = obj; return newObj; } }
+ var _buttonGroup = __webpack_require__(35);
-/**
- * Rule for validating whitespace.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param source The source object being validated.
- * @param errors An array of errors that this rule may add
- * validation errors to.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function whitespace(rule, value, source, errors, options) {
- if (/^\s+$/.test(value) || value === '') {
- errors.push(util.format(options.messages.whitespace, rule.fullField));
- }
-}
+ var _buttonGroup2 = _interopRequireDefault(_buttonGroup);
-exports["default"] = whitespace;
-module.exports = exports['default'];
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-/***/ }),
-/* 59 */
-/***/ (function(module, exports, __webpack_require__) {
+ /* istanbul ignore next */
+ _buttonGroup2.default.install = function (Vue) {
+ Vue.component(_buttonGroup2.default.name, _buttonGroup2.default);
+ };
-"use strict";
+ exports.default = _buttonGroup2.default;
+/***/ },
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+/***/ 35:
+/***/ function(module, exports, __webpack_require__) {
-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; };
+ var Component = __webpack_require__(3)(
+ /* script */
+ __webpack_require__(36),
+ /* template */
+ __webpack_require__(37),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
-var _util = __webpack_require__(0);
+ module.exports = Component.exports
-var util = _interopRequireWildcard(_util);
-var _required = __webpack_require__(28);
+/***/ },
-var _required2 = _interopRequireDefault(_required);
+/***/ 36:
+/***/ function(module, exports) {
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+ 'use strict';
-function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj["default"] = obj; return newObj; } }
+ exports.__esModule = true;
+ //
+ //
+ //
+ //
+ //
-/* eslint max-len:0 */
+ /**
+ * button
+ * @module components/basic/menu
+ * @desc 用于按钮组
+ * @param {string} label - 名称
+ */
+ exports.default = {
+ name: 'ElButtonGroup'
+ };
-var pattern = {
- // http://emailregex.com/
- email: /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,
- url: new RegExp('^(?!mailto:)(?:(?:http|https|ftp)://|//)(?:\\S+(?::\\S*)?@)?(?:(?:(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}(?:\\.(?:[0-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))|(?:(?:[a-z\\u00a1-\\uffff0-9]+-?)*[a-z\\u00a1-\\uffff0-9]+)(?:\\.(?:[a-z\\u00a1-\\uffff0-9]+-?)*[a-z\\u00a1-\\uffff0-9]+)*(?:\\.(?:[a-z\\u00a1-\\uffff]{2,})))|localhost)(?::\\d{2,5})?(?:(/|\\?|#)[^\\s]*)?$', 'i'),
- hex: /^#?([a-f0-9]{6}|[a-f0-9]{3})$/i
-};
+/***/ },
-var types = {
- integer: function integer(value) {
- return types.number(value) && parseInt(value, 10) === value;
- },
- "float": function float(value) {
- return types.number(value) && !types.integer(value);
- },
- array: function array(value) {
- return Array.isArray(value);
- },
- regexp: function regexp(value) {
- if (value instanceof RegExp) {
- return true;
- }
- try {
- return !!new RegExp(value);
- } catch (e) {
- return false;
- }
- },
- date: function date(value) {
- return typeof value.getTime === 'function' && typeof value.getMonth === 'function' && typeof value.getYear === 'function';
- },
- number: function number(value) {
- if (isNaN(value)) {
- return false;
- }
- return typeof value === 'number';
- },
- object: function object(value) {
- return (typeof value === 'undefined' ? 'undefined' : _typeof(value)) === 'object' && !types.array(value);
- },
- method: function method(value) {
- return typeof value === 'function';
- },
- email: function email(value) {
- return typeof value === 'string' && !!value.match(pattern.email);
- },
- url: function url(value) {
- return typeof value === 'string' && !!value.match(pattern.url);
- },
- hex: function hex(value) {
- return typeof value === 'string' && !!value.match(pattern.hex);
- }
-};
+/***/ 37:
+/***/ function(module, exports) {
-/**
- * Rule for validating the type of a value.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param source The source object being validated.
- * @param errors An array of errors that this rule may add
- * validation errors to.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function type(rule, value, source, errors, options) {
- if (rule.required && value === undefined) {
- (0, _required2["default"])(rule, value, source, errors, options);
- return;
- }
- var custom = ['integer', 'float', 'array', 'regexp', 'object', 'method', 'email', 'number', 'date', 'url', 'hex'];
- var ruleType = rule.type;
- if (custom.indexOf(ruleType) > -1) {
- if (!types[ruleType](value)) {
- errors.push(util.format(options.messages.types[ruleType], rule.fullField, rule.type));
- }
- // straight typeof check
- } else if (ruleType && (typeof value === 'undefined' ? 'undefined' : _typeof(value)) !== rule.type) {
- errors.push(util.format(options.messages.types[ruleType], rule.fullField, rule.type));
- }
-}
+ module.exports={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)
+ },staticRenderFns: []}
-exports["default"] = type;
-module.exports = exports['default'];
+/***/ }
+
+/******/ });
/***/ }),
-/* 60 */
+/* 51 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-
-var _util = __webpack_require__(0);
+exports.__esModule = true;
-var util = _interopRequireWildcard(_util);
+var _dom = __webpack_require__(4);
-function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj["default"] = obj; return newObj; } }
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
-/**
- * Rule for validating minimum and maximum allowed values.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param source The source object being validated.
- * @param errors An array of errors that this rule may add
- * validation errors to.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function range(rule, value, source, errors, options) {
- var len = typeof rule.len === 'number';
- var min = typeof rule.min === 'number';
- var max = typeof rule.max === 'number';
- var val = value;
- var key = null;
- var num = typeof value === 'number';
- var str = typeof value === 'string';
- var arr = Array.isArray(value);
- if (num) {
- key = 'number';
- } else if (str) {
- key = 'string';
- } else if (arr) {
- key = 'array';
- }
- // if the value is not of a supported type for range validation
- // the validation rule rule should use the
- // type property to also test for a particular type
- if (!key) {
- return false;
- }
- if (str || arr) {
- val = value.length;
+var Transition = function () {
+ function Transition() {
+ _classCallCheck(this, Transition);
}
- if (len) {
- if (val !== rule.len) {
- errors.push(util.format(options.messages[key].len, rule.fullField, rule.len));
+
+ Transition.prototype.beforeEnter = function beforeEnter(el) {
+ (0, _dom.addClass)(el, 'collapse-transition');
+ if (!el.dataset) el.dataset = {};
+
+ el.dataset.oldPaddingTop = el.style.paddingTop;
+ el.dataset.oldPaddingBottom = el.style.paddingBottom;
+
+ el.style.height = '0';
+ el.style.paddingTop = 0;
+ el.style.paddingBottom = 0;
+ };
+
+ Transition.prototype.enter = function enter(el) {
+ el.dataset.oldOverflow = el.style.overflow;
+ if (el.scrollHeight !== 0) {
+ el.style.height = el.scrollHeight + 'px';
+ el.style.paddingTop = el.dataset.oldPaddingTop;
+ el.style.paddingBottom = el.dataset.oldPaddingBottom;
+ } else {
+ el.style.height = '';
+ el.style.paddingTop = el.dataset.oldPaddingTop;
+ el.style.paddingBottom = el.dataset.oldPaddingBottom;
}
- } else if (min && !max && val < rule.min) {
- errors.push(util.format(options.messages[key].min, rule.fullField, rule.min));
- } else if (max && !min && val > rule.max) {
- errors.push(util.format(options.messages[key].max, rule.fullField, rule.max));
- } else if (min && max && (val < rule.min || val > rule.max)) {
- errors.push(util.format(options.messages[key].range, rule.fullField, rule.min, rule.max));
- }
-}
-exports["default"] = range;
-module.exports = exports['default'];
+ el.style.overflow = 'hidden';
+ };
-/***/ }),
-/* 61 */
-/***/ (function(module, exports, __webpack_require__) {
+ Transition.prototype.afterEnter = function afterEnter(el) {
+ // for safari: remove class then reset height is necessary
+ (0, _dom.removeClass)(el, 'collapse-transition');
+ el.style.height = '';
+ el.style.overflow = el.dataset.oldOverflow;
+ };
-"use strict";
+ Transition.prototype.beforeLeave = function beforeLeave(el) {
+ if (!el.dataset) el.dataset = {};
+ el.dataset.oldPaddingTop = el.style.paddingTop;
+ el.dataset.oldPaddingBottom = el.style.paddingBottom;
+ el.dataset.oldOverflow = el.style.overflow;
+ el.style.height = el.scrollHeight + 'px';
+ el.style.overflow = 'hidden';
+ };
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+ Transition.prototype.leave = function leave(el) {
+ if (el.scrollHeight !== 0) {
+ // for safari: add class after set height, or it will jump to zero height suddenly, weired
+ (0, _dom.addClass)(el, 'collapse-transition');
+ el.style.height = 0;
+ el.style.paddingTop = 0;
+ el.style.paddingBottom = 0;
+ }
+ };
-var _util = __webpack_require__(0);
+ Transition.prototype.afterLeave = function afterLeave(el) {
+ (0, _dom.removeClass)(el, 'collapse-transition');
+ el.style.height = '';
+ el.style.overflow = el.dataset.oldOverflow;
+ el.style.paddingTop = el.dataset.oldPaddingTop;
+ el.style.paddingBottom = el.dataset.oldPaddingBottom;
+ };
-var util = _interopRequireWildcard(_util);
+ return Transition;
+}();
-function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj["default"] = obj; return newObj; } }
+exports.default = {
+ name: 'ElCollapseTransition',
+ functional: true,
+ render: function render(h, _ref) {
+ var children = _ref.children;
-var ENUM = 'enum';
+ var data = {
+ on: new Transition()
+ };
-/**
- * Rule for validating a value exists in an enumerable list.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param source The source object being validated.
- * @param errors An array of errors that this rule may add
- * validation errors to.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function enumerable(rule, value, source, errors, options) {
- rule[ENUM] = Array.isArray(rule[ENUM]) ? rule[ENUM] : [];
- if (rule[ENUM].indexOf(value) === -1) {
- errors.push(util.format(options.messages[ENUM], rule.fullField, rule[ENUM].join(', ')));
+ return h('transition', data, children);
}
-}
+};
+
+/***/ }),
+/* 52 */
+/***/ (function(module, exports, __webpack_require__) {
+
+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] = {
+/******/ exports: {},
+/******/ id: moduleId,
+/******/ loaded: false
+/******/ };
+
+/******/ // Execute the module function
+/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
+
+/******/ // Flag the module as loaded
+/******/ module.loaded = true;
+
+/******/ // Return the exports of the module
+/******/ return module.exports;
+/******/ }
-exports["default"] = enumerable;
-module.exports = exports['default'];
-/***/ }),
-/* 62 */
-/***/ (function(module, exports, __webpack_require__) {
+/******/ // expose the modules object (__webpack_modules__)
+/******/ __webpack_require__.m = modules;
-"use strict";
+/******/ // expose the module cache
+/******/ __webpack_require__.c = installedModules;
+/******/ // __webpack_public_path__
+/******/ __webpack_require__.p = "/dist/";
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+/******/ // Load entry module and return exports
+/******/ return __webpack_require__(0);
+/******/ })
+/************************************************************************/
+/******/ ({
-var _util = __webpack_require__(0);
+/***/ 0:
+/***/ function(module, exports, __webpack_require__) {
-var util = _interopRequireWildcard(_util);
+ module.exports = __webpack_require__(65);
-function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj["default"] = obj; return newObj; } }
-/**
- * Rule for validating a regular expression pattern.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param source The source object being validated.
- * @param errors An array of errors that this rule may add
- * validation errors to.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function pattern(rule, value, source, errors, options) {
- if (rule.pattern instanceof RegExp) {
- if (!rule.pattern.test(value)) {
- errors.push(util.format(options.messages.pattern.mismatch, rule.fullField, value, rule.pattern));
- }
- }
-}
+/***/ },
-exports["default"] = pattern;
-module.exports = exports['default'];
+/***/ 3:
+/***/ function(module, exports) {
-/***/ }),
-/* 63 */
-/***/ (function(module, exports, __webpack_require__) {
+ /* globals __VUE_SSR_CONTEXT__ */
-"use strict";
+ // this module is a runtime utility for cleaner component module output and will
+ // be included in the final webpack user bundle
+ module.exports = function normalizeComponent (
+ rawScriptExports,
+ compiledTemplate,
+ injectStyles,
+ scopeId,
+ moduleIdentifier /* server only */
+ ) {
+ var esModule
+ var scriptExports = rawScriptExports = rawScriptExports || {}
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+ // ES6 modules interop
+ var type = typeof rawScriptExports.default
+ if (type === 'object' || type === 'function') {
+ esModule = rawScriptExports
+ scriptExports = rawScriptExports.default
+ }
-var _rule = __webpack_require__(1);
+ // Vue.extend constructor export interop
+ var options = typeof scriptExports === 'function'
+ ? scriptExports.options
+ : scriptExports
-var _rule2 = _interopRequireDefault(_rule);
+ // render functions
+ if (compiledTemplate) {
+ options.render = compiledTemplate.render
+ options.staticRenderFns = compiledTemplate.staticRenderFns
+ }
-var _util = __webpack_require__(0);
+ // scopedId
+ if (scopeId) {
+ options._scopeId = scopeId
+ }
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+ var hook
+ if (moduleIdentifier) { // server build
+ hook = function (context) {
+ // 2.3 injection
+ context = context || (this.$vnode && this.$vnode.ssrContext)
+ // 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 = injectStyles
+ }
-/**
- * Validates a function.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function method(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value) && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options);
- if (value !== undefined) {
- _rule2["default"].type(rule, value, source, errors, options);
- }
- }
- callback(errors);
-}
+ if (hook) {
+ // inject component registration as beforeCreate hook
+ var existing = options.beforeCreate
+ options.beforeCreate = existing
+ ? [].concat(existing, hook)
+ : [hook]
+ }
-exports["default"] = method;
-module.exports = exports['default'];
+ return {
+ esModule: esModule,
+ exports: scriptExports,
+ options: options
+ }
+ }
-/***/ }),
-/* 64 */
-/***/ (function(module, exports, __webpack_require__) {
-"use strict";
+/***/ },
+/***/ 14:
+/***/ function(module, exports) {
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+ module.exports = __webpack_require__(5);
-var _rule = __webpack_require__(1);
+/***/ },
-var _rule2 = _interopRequireDefault(_rule);
+/***/ 65:
+/***/ function(module, exports, __webpack_require__) {
-var _util = __webpack_require__(0);
+ 'use strict';
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+ exports.__esModule = true;
-/**
- * Validates a number.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function number(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value) && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options);
- if (value !== undefined) {
- _rule2["default"].type(rule, value, source, errors, options);
- _rule2["default"].range(rule, value, source, errors, options);
- }
- }
- callback(errors);
-}
+ var _checkbox = __webpack_require__(66);
-exports["default"] = number;
-module.exports = exports['default'];
+ var _checkbox2 = _interopRequireDefault(_checkbox);
-/***/ }),
-/* 65 */
-/***/ (function(module, exports, __webpack_require__) {
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-"use strict";
+ /* istanbul ignore next */
+ _checkbox2.default.install = function (Vue) {
+ Vue.component(_checkbox2.default.name, _checkbox2.default);
+ };
+ exports.default = _checkbox2.default;
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+/***/ },
-var _util = __webpack_require__(0);
+/***/ 66:
+/***/ function(module, exports, __webpack_require__) {
-var _rule = __webpack_require__(1);
+ var Component = __webpack_require__(3)(
+ /* script */
+ __webpack_require__(67),
+ /* template */
+ __webpack_require__(68),
+ /* styles */
+ null,
+ /* scopeId */
+ null,
+ /* moduleIdentifier (server only) */
+ null
+ )
-var _rule2 = _interopRequireDefault(_rule);
+ module.exports = Component.exports
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-/**
- * Validates a boolean.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function boolean(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value) && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options);
- if (value !== undefined) {
- _rule2["default"].type(rule, value, source, errors, options);
- }
- }
- callback(errors);
-}
+/***/ },
-exports["default"] = boolean;
-module.exports = exports['default'];
+/***/ 67:
+/***/ function(module, exports, __webpack_require__) {
-/***/ }),
-/* 66 */
-/***/ (function(module, exports, __webpack_require__) {
+ 'use strict';
-"use strict";
+ exports.__esModule = true;
+ var _emitter = __webpack_require__(14);
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+ var _emitter2 = _interopRequireDefault(_emitter);
-var _rule = __webpack_require__(1);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-var _rule2 = _interopRequireDefault(_rule);
+ exports.default = {
+ name: 'ElCheckbox',
-var _util = __webpack_require__(0);
+ mixins: [_emitter2.default],
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+ componentName: 'ElCheckbox',
-/**
- * Validates the regular expression type.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function regexp(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value) && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options);
- if (!(0, _util.isEmptyValue)(value)) {
- _rule2["default"].type(rule, value, source, errors, options);
- }
- }
- callback(errors);
-}
+ data: function data() {
+ return {
+ selfModel: false,
+ focus: false
+ };
+ },
-exports["default"] = regexp;
-module.exports = exports['default'];
-/***/ }),
-/* 67 */
-/***/ (function(module, exports, __webpack_require__) {
+ computed: {
+ model: {
+ get: function get() {
+ return this.isGroup ? this.store : this.value !== undefined ? this.value : this.selfModel;
+ },
+ set: function set(val) {
+ if (this.isGroup) {
+ var isLimitExceeded = false;
+ this._checkboxGroup.min !== undefined && val.length < this._checkboxGroup.min && (isLimitExceeded = true);
-"use strict";
+ this._checkboxGroup.max !== undefined && val.length > this._checkboxGroup.max && (isLimitExceeded = true);
+ isLimitExceeded === false && this.dispatch('ElCheckboxGroup', 'input', [val]);
+ } else {
+ this.$emit('input', val);
+ this.selfModel = val;
+ }
+ }
+ },
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+ 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;
+ }
+ },
-var _rule = __webpack_require__(1);
+ props: {
+ value: {},
+ label: {},
+ indeterminate: Boolean,
+ disabled: Boolean,
+ checked: Boolean,
+ name: String,
+ trueLabel: [String, Number],
+ falseLabel: [String, Number]
+ },
-var _rule2 = _interopRequireDefault(_rule);
+ 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;
-var _util = __webpack_require__(0);
+ this.$emit('change', ev);
+ if (this.isGroup) {
+ this.$nextTick(function (_) {
+ _this.dispatch('ElCheckboxGroup', 'change', [_this._checkboxGroup.value]);
+ });
+ }
+ }
+ },
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+ created: function created() {
+ this.checked && this.addToStore();
+ }
+ }; //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+ //
+
+/***/ },
+
+/***/ 68:
+/***/ function(module, exports) {
+
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('label', {
+ staticClass: "el-checkbox"
+ }, [_c('span', {
+ staticClass: "el-checkbox__input",
+ class: {
+ 'is-disabled': _vm.disabled,
+ 'is-checked': _vm.isChecked,
+ 'is-indeterminate': _vm.indeterminate,
+ 'is-focus': _vm.focus
+ }
+ }, [_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",
+ "name": _vm.name,
+ "disabled": _vm.disabled,
+ "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": _vm.handleChange,
+ "focus": function($event) {
+ _vm.focus = true
+ },
+ "blur": function($event) {
+ _vm.focus = false
+ },
+ "__c": 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 ($$c) {
+ $$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
+ }
+ }
+ }
+ }) : _c('input', {
+ directives: [{
+ name: "model",
+ rawName: "v-model",
+ value: (_vm.model),
+ expression: "model"
+ }],
+ staticClass: "el-checkbox__original",
+ attrs: {
+ "type": "checkbox",
+ "disabled": _vm.disabled,
+ "name": _vm.name
+ },
+ domProps: {
+ "value": _vm.label,
+ "checked": Array.isArray(_vm.model) ? _vm._i(_vm.model, _vm.label) > -1 : (_vm.model)
+ },
+ on: {
+ "change": _vm.handleChange,
+ "focus": function($event) {
+ _vm.focus = true
+ },
+ "blur": function($event) {
+ _vm.focus = false
+ },
+ "__c": 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 ($$c) {
+ $$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.$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()])
+ },staticRenderFns: []}
-/**
- * Validates a number is an integer.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function integer(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value) && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options);
- if (value !== undefined) {
- _rule2["default"].type(rule, value, source, errors, options);
- _rule2["default"].range(rule, value, source, errors, options);
- }
- }
- callback(errors);
-}
+/***/ }
-exports["default"] = integer;
-module.exports = exports['default'];
+/******/ });
/***/ }),
-/* 68 */
+/* 53 */
/***/ (function(module, exports, __webpack_require__) {
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-
-var _rule = __webpack_require__(1);
-
-var _rule2 = _interopRequireDefault(_rule);
-
-var _util = __webpack_require__(0);
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-/**
- * Validates a number is a floating point number.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function floatFn(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value) && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options);
- if (value !== undefined) {
- _rule2["default"].type(rule, value, source, errors, options);
- _rule2["default"].range(rule, value, source, errors, options);
- }
- }
- callback(errors);
-}
-
-exports["default"] = floatFn;
-module.exports = exports['default'];
+module.exports =
+/******/ (function(modules) { // webpackBootstrap
+/******/ // The module cache
+/******/ var installedModules = {};
-/***/ }),
-/* 69 */
-/***/ (function(module, exports, __webpack_require__) {
+/******/ // The require function
+/******/ function __webpack_require__(moduleId) {
-"use strict";
+/******/ // 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] = {
+/******/ exports: {},
+/******/ id: moduleId,
+/******/ loaded: false
+/******/ };
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+/******/ // Execute the module function
+/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
-var _rule = __webpack_require__(1);
+/******/ // Flag the module as loaded
+/******/ module.loaded = true;
-var _rule2 = _interopRequireDefault(_rule);
+/******/ // Return the exports of the module
+/******/ return module.exports;
+/******/ }
-var _util = __webpack_require__(0);
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+/******/ // expose the modules object (__webpack_modules__)
+/******/ __webpack_require__.m = modules;
-/**
- * Validates an array.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function array(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value, 'array') && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options, 'array');
- if (!(0, _util.isEmptyValue)(value, 'array')) {
- _rule2["default"].type(rule, value, source, errors, options);
- _rule2["default"].range(rule, value, source, errors, options);
- }
- }
- callback(errors);
-}
+/******/ // expose the module cache
+/******/ __webpack_require__.c = installedModules;
-exports["default"] = array;
-module.exports = exports['default'];
+/******/ // __webpack_public_path__
+/******/ __webpack_require__.p = "/dist/";
-/***/ }),
-/* 70 */
-/***/ (function(module, exports, __webpack_require__) {
+/******/ // Load entry module and return exports
+/******/ return __webpack_require__(0);
+/******/ })
+/************************************************************************/
+/******/ ({
-"use strict";
+/***/ 0:
+/***/ function(module, exports, __webpack_require__) {
+ module.exports = __webpack_require__(345);
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-var _rule = __webpack_require__(1);
+/***/ },
-var _rule2 = _interopRequireDefault(_rule);
+/***/ 13:
+/***/ function(module, exports) {
-var _util = __webpack_require__(0);
+ module.exports = __webpack_require__(13);
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+/***/ },
-/**
- * Validates an object.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function object(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value) && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options);
- if (value !== undefined) {
- _rule2["default"].type(rule, value, source, errors, options);
- }
- }
- callback(errors);
-}
+/***/ 55:
+/***/ function(module, exports) {
-exports["default"] = object;
-module.exports = exports['default'];
+ module.exports = __webpack_require__(3);
-/***/ }),
-/* 71 */
-/***/ (function(module, exports, __webpack_require__) {
+/***/ },
-"use strict";
+/***/ 63:
+/***/ function(module, exports) {
+ module.exports = __webpack_require__(9);
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+/***/ },
-var _rule = __webpack_require__(1);
+/***/ 197:
+/***/ function(module, exports) {
-var _rule2 = _interopRequireDefault(_rule);
+ module.exports = __webpack_require__(27);
-var _util = __webpack_require__(0);
+/***/ },
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+/***/ 345:
+/***/ function(module, exports, __webpack_require__) {
-var ENUM = 'enum';
+ 'use strict';
-/**
- * Validates an enumerable list.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function enumerable(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value) && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options);
- if (value) {
- _rule2["default"][ENUM](rule, value, source, errors, options);
- }
- }
- callback(errors);
-}
+ exports.__esModule = true;
-exports["default"] = enumerable;
-module.exports = exports['default'];
+ var _main = __webpack_require__(346);
-/***/ }),
-/* 72 */
-/***/ (function(module, exports, __webpack_require__) {
+ var _main2 = _interopRequireDefault(_main);
-"use strict";
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+ /* istanbul ignore next */
+ _main2.default.install = function (Vue) {
+ Vue.component(_main2.default.name, _main2.default);
+ };
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+ exports.default = _main2.default;
-var _rule = __webpack_require__(1);
+/***/ },
-var _rule2 = _interopRequireDefault(_rule);
+/***/ 346:
+/***/ function(module, exports, __webpack_require__) {
-var _util = __webpack_require__(0);
+ 'use strict';
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+ exports.__esModule = true;
-/**
- * Validates a regular expression pattern.
- *
- * Performs validation when a rule only contains
- * a pattern property but is not declared as a string type.
- *
- * @param rule The validation rule.
- * @param value The value of the field on the source object.
- * @param callback The callback function.
- * @param source The source object being validated.
- * @param options The validation options.
- * @param options.messages The validation messages.
- */
-function pattern(rule, value, callback, source, options) {
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- if (validate) {
- if ((0, _util.isEmptyValue)(value, 'string') && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options);
- if (!(0, _util.isEmptyValue)(value, 'string')) {
- _rule2["default"].pattern(rule, value, source, errors, options);
- }
- }
- callback(errors);
-}
+ var _vuePopper = __webpack_require__(13);
-exports["default"] = pattern;
-module.exports = exports['default'];
+ var _vuePopper2 = _interopRequireDefault(_vuePopper);
-/***/ }),
-/* 73 */
-/***/ (function(module, exports, __webpack_require__) {
+ var _debounce = __webpack_require__(63);
-"use strict";
+ var _debounce2 = _interopRequireDefault(_debounce);
+ var _vdom = __webpack_require__(197);
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+ var _vue = __webpack_require__(55);
-var _rule = __webpack_require__(1);
+ var _vue2 = _interopRequireDefault(_vue);
-var _rule2 = _interopRequireDefault(_rule);
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-var _util = __webpack_require__(0);
+ exports.default = {
+ name: 'ElTooltip',
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+ mixins: [_vuePopper2.default],
-function date(rule, value, callback, source, options) {
- // console.log('integer rule called %j', rule);
- var errors = [];
- var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
- // console.log('validate on %s value', value);
- if (validate) {
- if ((0, _util.isEmptyValue)(value) && !rule.required) {
- return callback();
- }
- _rule2["default"].required(rule, value, source, errors, options);
- if (!(0, _util.isEmptyValue)(value)) {
- _rule2["default"].type(rule, value, source, errors, options);
- if (value) {
- _rule2["default"].range(rule, value.getTime(), source, errors, options);
- }
- }
- }
- callback(errors);
-}
+ props: {
+ openDelay: {
+ type: Number,
+ default: 0
+ },
+ disabled: Boolean,
+ manual: Boolean,
+ effect: {
+ type: String,
+ default: 'dark'
+ },
+ 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
+ }
+ },
-exports["default"] = date;
-module.exports = exports['default'];
+ beforeCreate: function beforeCreate() {
+ var _this = this;
-/***/ }),
-/* 74 */
-/***/ (function(module, exports, __webpack_require__) {
+ if (this.$isServer) return;
-"use strict";
+ this.popperVM = new _vue2.default({
+ data: { node: '' },
+ render: function render(h) {
+ return this.node;
+ }
+ }).$mount();
+ this.debounceClose = (0, _debounce2.default)(200, function () {
+ return _this.handleClosePopper();
+ });
+ },
+ render: function render(h) {
+ var _this2 = this;
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
+ 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);
+ }
+ },
-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; };
+ ref: 'popper',
+ directives: [{
+ name: 'show',
+ value: !this.disabled && this.showPopper
+ }],
-var _rule = __webpack_require__(1);
+ 'class': ['el-tooltip__popper', 'is-' + this.effect, this.popperClass] },
+ [this.$slots.content || this.content]
+ )]
+ );
+ }
-var _rule2 = _interopRequireDefault(_rule);
+ if (!this.$slots.default || !this.$slots.default.length) return this.$slots.default;
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
+ var vnode = (0, _vdom.getFirstComponentChild)(this.$slots.default);
+ if (!vnode) return vnode;
+ var data = vnode.data = vnode.data || {};
+ var on = vnode.data.on = vnode.data.on || {};
+ var nativeOn = vnode.data.nativeOn = vnode.data.nativeOn || {};
-function required(rule, value, callback, source, options) {
- var errors = [];
- var type = Array.isArray(value) ? 'array' : typeof value === 'undefined' ? 'undefined' : _typeof(value);
- _rule2["default"].required(rule, value, source, errors, options, type);
- callback(errors);
-}
+ on.mouseenter = this.addEventHandle(on.mouseenter, function () {
+ _this2.setExpectedState(true);_this2.handleShowPopper();
+ });
+ on.mouseleave = this.addEventHandle(on.mouseleave, function () {
+ _this2.setExpectedState(false);_this2.debounceClose();
+ });
+ nativeOn.mouseenter = this.addEventHandle(nativeOn.mouseenter, function () {
+ _this2.setExpectedState(true);_this2.handleShowPopper();
+ });
+ nativeOn.mouseleave = this.addEventHandle(nativeOn.mouseleave, function () {
+ _this2.setExpectedState(false);_this2.debounceClose();
+ });
+ data.staticClass = this.concatClass(data.staticClass, 'el-tooltip');
-exports["default"] = required;
-module.exports = exports['default'];
+ return vnode;
+ },
+ mounted: function mounted() {
+ this.referenceElm = this.$el;
+ },
-/***/ }),
-/* 75 */
-/***/ (function(module, exports, __webpack_require__) {
-"use strict";
+ methods: {
+ addEventHandle: function addEventHandle(old, fn) {
+ return old ? Array.isArray(old) ? old.concat(fn) : [old, fn] : fn;
+ },
+ concatClass: function concatClass(a, b) {
+ if (a && a.indexOf(b) > -1) return a;
+ return a ? b ? a + ' ' + b : a : b || '';
+ },
+ handleShowPopper: function handleShowPopper() {
+ var _this3 = this;
+ if (!this.expectedState || this.manual) return;
+ clearTimeout(this.timeout);
+ this.timeout = setTimeout(function () {
+ _this3.showPopper = true;
+ }, this.openDelay);
+ },
+ handleClosePopper: function handleClosePopper() {
+ if (this.enterable && this.expectedState || this.manual) return;
+ clearTimeout(this.timeout);
+ this.showPopper = false;
+ },
+ setExpectedState: function setExpectedState(expectedState) {
+ this.expectedState = expectedState;
+ }
+ }
+ };
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports.newMessages = newMessages;
-function newMessages() {
- return {
- "default": 'Validation error on field %s',
- required: '%s is required',
- "enum": '%s must be one of %s',
- whitespace: '%s cannot be empty',
- date: {
- format: '%s date %s is invalid for format %s',
- parse: '%s date could not be parsed, %s is invalid ',
- invalid: '%s date %s is invalid'
- },
- types: {
- string: '%s is not a %s',
- method: '%s is not a %s (function)',
- array: '%s is not an %s',
- object: '%s is not an %s',
- number: '%s is not a %s',
- date: '%s is not a %s',
- "boolean": '%s is not a %s',
- integer: '%s is not an %s',
- "float": '%s is not a %s',
- regexp: '%s is not a valid %s',
- email: '%s is not a valid %s',
- url: '%s is not a valid %s',
- hex: '%s is not a valid %s'
- },
- string: {
- len: '%s must be exactly %s characters',
- min: '%s must be at least %s characters',
- max: '%s cannot be longer than %s characters',
- range: '%s must be between %s and %s characters'
- },
- number: {
- len: '%s must equal %s',
- min: '%s cannot be less than %s',
- max: '%s cannot be greater than %s',
- range: '%s must be between %s and %s'
- },
- array: {
- len: '%s must be exactly %s in length',
- min: '%s cannot be less than %s in length',
- max: '%s cannot be greater than %s in length',
- range: '%s must be between %s and %s in length'
- },
- pattern: {
- mismatch: '%s value %s does not match pattern %s'
- },
- clone: function clone() {
- var cloned = JSON.parse(JSON.stringify(this));
- cloned.clone = this.clone;
- return cloned;
- }
- };
-}
+/***/ }
-var messages = exports.messages = newMessages();
+/******/ });
/***/ }),
-/* 76 */
+/* 54 */
/***/ (function(module, exports, __webpack_require__) {
module.exports =
@@ -68815,7 +68376,7 @@ module.exports =
/***/ 0:
/***/ function(module, exports, __webpack_require__) {
- module.exports = __webpack_require__(172);
+ module.exports = __webpack_require__(73);
/***/ },
@@ -68904,57 +68465,43 @@ module.exports =
/***/ },
-/***/ 9:
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(11);
-
-/***/ },
-
-/***/ 63:
-/***/ function(module, exports) {
-
- module.exports = __webpack_require__(9);
-
-/***/ },
-
-/***/ 123:
+/***/ 14:
/***/ function(module, exports) {
- module.exports = __webpack_require__(4);
+ module.exports = __webpack_require__(5);
/***/ },
-/***/ 172:
+/***/ 73:
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _inputNumber = __webpack_require__(173);
+ var _checkboxGroup = __webpack_require__(74);
- var _inputNumber2 = _interopRequireDefault(_inputNumber);
+ var _checkboxGroup2 = _interopRequireDefault(_checkboxGroup);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/* istanbul ignore next */
- _inputNumber2.default.install = function (Vue) {
- Vue.component(_inputNumber2.default.name, _inputNumber2.default);
+ _checkboxGroup2.default.install = function (Vue) {
+ Vue.component(_checkboxGroup2.default.name, _checkboxGroup2.default);
};
- exports.default = _inputNumber2.default;
+ exports.default = _checkboxGroup2.default;
/***/ },
-/***/ 173:
+/***/ 74:
/***/ function(module, exports, __webpack_require__) {
var Component = __webpack_require__(3)(
/* script */
- __webpack_require__(174),
+ __webpack_require__(75),
/* template */
- __webpack_require__(175),
+ __webpack_require__(76),
/* styles */
null,
/* scopeId */
@@ -68968,3250 +68515,3415 @@ module.exports =
/***/ },
-/***/ 174:
+/***/ 75:
/***/ function(module, exports, __webpack_require__) {
'use strict';
exports.__esModule = true;
- var _input = __webpack_require__(9);
-
- var _input2 = _interopRequireDefault(_input);
-
- var _dom = __webpack_require__(123);
-
- var _debounce = __webpack_require__(63);
+ var _emitter = __webpack_require__(14);
- var _debounce2 = _interopRequireDefault(_debounce);
+ var _emitter2 = _interopRequireDefault(_emitter);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
exports.default = {
- name: 'ElInputNumber',
- directives: {
- repeatClick: {
- 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 (new Date() - startTime < 100) {
- handler();
- }
- clearInterval(interval);
- interval = null;
- };
+ name: 'ElCheckboxGroup',
+
+ componentName: 'ElCheckboxGroup',
+
+ mixins: [_emitter2.default],
- (0, _dom.on)(el, 'mousedown', function () {
- startTime = new Date();
- (0, _dom.once)(document, 'mouseup', clear);
- clearInterval(interval);
- interval = setInterval(handler, 100);
- });
- }
- }
- },
- components: {
- ElInput: _input2.default
- },
props: {
- step: {
- type: Number,
- default: 1
- },
- max: {
- type: Number,
- default: Infinity
- },
- min: {
- type: Number,
- default: -Infinity
- },
- value: {
- default: 0
- },
- disabled: Boolean,
+ value: {},
+ min: Number,
+ max: Number,
size: String,
- controls: {
- type: Boolean,
- default: true
- },
- debounce: {
- type: Number,
- default: 300
- }
- },
- data: function data() {
- return {
- currentValue: 0
- };
+ fill: String,
+ textColor: String
},
watch: {
- value: {
- immediate: true,
- handler: function handler(value) {
- var newVal = Number(value);
- if (isNaN(newVal)) return;
- if (newVal >= this.max) newVal = this.max;
- if (newVal <= this.min) newVal = this.min;
- this.currentValue = newVal;
- this.$emit('input', newVal);
- }
+ value: function value(_value) {
+ this.dispatch('ElFormItem', 'el.form.change', [_value]);
}
- },
- 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;
- },
- precision: function precision() {
- var value = this.value,
- step = this.step,
- getPrecision = this.getPrecision;
+ }
+ };
+
+/***/ },
+
+/***/ 76:
+/***/ function(module, exports) {
+
+ module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
+ return _c('div', {
+ staticClass: "el-checkbox-group"
+ }, [_vm._t("default")], 2)
+ },staticRenderFns: []}
+
+/***/ }
+
+/******/ });
+
+/***/ }),
+/* 55 */
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+var __WEBPACK_AMD_DEFINE_RESULT__;
+
+/* Modified from https://github.com/taylorhakes/fecha
+ *
+ * The MIT License (MIT)
+ *
+ * Copyright (c) 2015 Taylor Hakes
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all
+ * copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ */
+
+/*eslint-disable*/
+// 把 YYYY-MM-DD 改成了 yyyy-MM-dd
+(function (main) {
+ 'use strict';
+
+ /**
+ * Parse or format dates
+ * @class fecha
+ */
+
+ var fecha = {};
+ var token = /d{1,4}|M{1,4}|yy(?:yy)?|S{1,3}|Do|ZZ|([HhMsDm])\1?|[aA]|"[^"]*"|'[^']*'/g;
+ var twoDigits = /\d\d?/;
+ var threeDigits = /\d{3}/;
+ var fourDigits = /\d{4}/;
+ var word = /[0-9]*['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+|[\u0600-\u06FF\/]+(\s*?[\u0600-\u06FF]+){1,2}/i;
+ var noop = function noop() {};
+
+ function shorten(arr, sLen) {
+ var newArr = [];
+ for (var i = 0, len = arr.length; i < len; i++) {
+ newArr.push(arr[i].substr(0, sLen));
+ }
+ return newArr;
+ }
+
+ function monthUpdate(arrName) {
+ return function (d, v, i18n) {
+ var index = i18n[arrName].indexOf(v.charAt(0).toUpperCase() + v.substr(1).toLowerCase());
+ if (~index) {
+ d.month = index;
+ }
+ };
+ }
+
+ function pad(val, len) {
+ val = String(val);
+ len = len || 2;
+ while (val.length < len) {
+ val = '0' + val;
+ }
+ return val;
+ }
+
+ var dayNames = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
+ var monthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];
+ var monthNamesShort = shorten(monthNames, 3);
+ var dayNamesShort = shorten(dayNames, 3);
+ fecha.i18n = {
+ dayNamesShort: dayNamesShort,
+ dayNames: dayNames,
+ monthNamesShort: monthNamesShort,
+ monthNames: monthNames,
+ amPm: ['am', 'pm'],
+ DoFn: function DoFn(D) {
+ return D + ['th', 'st', 'nd', 'rd'][D % 10 > 3 ? 0 : (D - D % 10 !== 10) * D % 10];
+ }
+ };
+
+ var formatFlags = {
+ D: function D(dateObj) {
+ return dateObj.getDay();
+ },
+ DD: function DD(dateObj) {
+ return pad(dateObj.getDay());
+ },
+ Do: function Do(dateObj, i18n) {
+ return i18n.DoFn(dateObj.getDate());
+ },
+ d: function d(dateObj) {
+ return dateObj.getDate();
+ },
+ dd: function dd(dateObj) {
+ return pad(dateObj.getDate());
+ },
+ ddd: function ddd(dateObj, i18n) {
+ return i18n.dayNamesShort[dateObj.getDay()];
+ },
+ dddd: function dddd(dateObj, i18n) {
+ return i18n.dayNames[dateObj.getDay()];
+ },
+ M: function M(dateObj) {
+ return dateObj.getMonth() + 1;
+ },
+ MM: function MM(dateObj) {
+ return pad(dateObj.getMonth() + 1);
+ },
+ MMM: function MMM(dateObj, i18n) {
+ return i18n.monthNamesShort[dateObj.getMonth()];
+ },
+ MMMM: function MMMM(dateObj, i18n) {
+ return i18n.monthNames[dateObj.getMonth()];
+ },
+ yy: function yy(dateObj) {
+ return String(dateObj.getFullYear()).substr(2);
+ },
+ yyyy: function yyyy(dateObj) {
+ return dateObj.getFullYear();
+ },
+ h: function h(dateObj) {
+ return dateObj.getHours() % 12 || 12;
+ },
+ hh: function hh(dateObj) {
+ return pad(dateObj.getHours() % 12 || 12);
+ },
+ H: function H(dateObj) {
+ return dateObj.getHours();
+ },
+ HH: function HH(dateObj) {
+ return pad(dateObj.getHours());
+ },
+ m: function m(dateObj) {
+ return dateObj.getMinutes();
+ },
+ mm: function mm(dateObj) {
+ return pad(dateObj.getMinutes());
+ },
+ s: function s(dateObj) {
+ return dateObj.getSeconds();
+ },
+ ss: function ss(dateObj) {
+ return pad(dateObj.getSeconds());
+ },
+ S: function S(dateObj) {
+ return Math.round(dateObj.getMilliseconds() / 100);
+ },
+ SS: function SS(dateObj) {
+ return pad(Math.round(dateObj.getMilliseconds() / 10), 2);
+ },
+ SSS: function SSS(dateObj) {
+ return pad(dateObj.getMilliseconds(), 3);
+ },
+ a: function a(dateObj, i18n) {
+ return dateObj.getHours() < 12 ? i18n.amPm[0] : i18n.amPm[1];
+ },
+ A: function A(dateObj, i18n) {
+ return dateObj.getHours() < 12 ? i18n.amPm[0].toUpperCase() : i18n.amPm[1].toUpperCase();
+ },
+ ZZ: function ZZ(dateObj) {
+ var o = dateObj.getTimezoneOffset();
+ return (o > 0 ? '-' : '+') + pad(Math.floor(Math.abs(o) / 60) * 100 + Math.abs(o) % 60, 4);
+ }
+ };
+
+ var parseFlags = {
+ d: [twoDigits, function (d, v) {
+ d.day = v;
+ }],
+ M: [twoDigits, function (d, v) {
+ d.month = v - 1;
+ }],
+ yy: [twoDigits, function (d, v) {
+ var da = new Date(),
+ cent = +('' + da.getFullYear()).substr(0, 2);
+ d.year = '' + (v > 68 ? cent - 1 : cent) + v;
+ }],
+ h: [twoDigits, function (d, v) {
+ d.hour = v;
+ }],
+ m: [twoDigits, function (d, v) {
+ d.minute = v;
+ }],
+ s: [twoDigits, function (d, v) {
+ d.second = v;
+ }],
+ yyyy: [fourDigits, function (d, v) {
+ d.year = v;
+ }],
+ S: [/\d/, function (d, v) {
+ d.millisecond = v * 100;
+ }],
+ SS: [/\d{2}/, function (d, v) {
+ d.millisecond = v * 10;
+ }],
+ SSS: [threeDigits, function (d, v) {
+ d.millisecond = v;
+ }],
+ D: [twoDigits, noop],
+ ddd: [word, noop],
+ MMM: [word, monthUpdate('monthNamesShort')],
+ MMMM: [word, monthUpdate('monthNames')],
+ a: [word, function (d, v, i18n) {
+ var val = v.toLowerCase();
+ if (val === i18n.amPm[0]) {
+ d.isPm = false;
+ } else if (val === i18n.amPm[1]) {
+ d.isPm = true;
+ }
+ }],
+ ZZ: [/[\+\-]\d\d:?\d\d/, function (d, v) {
+ var parts = (v + '').match(/([\+\-]|\d\d)/gi),
+ minutes;
+
+ if (parts) {
+ minutes = +(parts[1] * 60) + parseInt(parts[2], 10);
+ d.timezoneOffset = parts[0] === '+' ? minutes : -minutes;
+ }
+ }]
+ };
+ parseFlags.DD = parseFlags.D;
+ parseFlags.dddd = parseFlags.ddd;
+ parseFlags.Do = parseFlags.dd = parseFlags.d;
+ parseFlags.mm = parseFlags.m;
+ parseFlags.hh = parseFlags.H = parseFlags.HH = parseFlags.h;
+ parseFlags.MM = parseFlags.M;
+ parseFlags.ss = parseFlags.s;
+ parseFlags.A = parseFlags.a;
+
+ // Some common format strings
+ fecha.masks = {
+ 'default': 'ddd MMM dd yyyy HH:mm:ss',
+ shortDate: 'M/D/yy',
+ mediumDate: 'MMM d, yyyy',
+ longDate: 'MMMM d, yyyy',
+ fullDate: 'dddd, MMMM d, yyyy',
+ shortTime: 'HH:mm',
+ mediumTime: 'HH:mm:ss',
+ longTime: 'HH:mm:ss.SSS'
+ };
+
+ /***
+ * Format a date
+ * @method format
+ * @param {Date|number} dateObj
+ * @param {string} mask Format of the date, i.e. 'mm-dd-yy' or 'shortDate'
+ */
+ fecha.format = function (dateObj, mask, i18nSettings) {
+ var i18n = i18nSettings || fecha.i18n;
+
+ if (typeof dateObj === 'number') {
+ dateObj = new Date(dateObj);
+ }
+
+ if (Object.prototype.toString.call(dateObj) !== '[object Date]' || isNaN(dateObj.getTime())) {
+ throw new Error('Invalid Date in fecha.format');
+ }
- return Math.max(getPrecision(value), getPrecision(step));
- }
- },
- methods: {
- toPrecision: function toPrecision(num, precision) {
- if (precision === undefined) precision = this.precision;
- return parseFloat(parseFloat(Number(num).toFixed(precision)));
- },
- getPrecision: function getPrecision(value) {
- 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') return this.currentValue;
+ mask = fecha.masks[mask] || mask || fecha.masks['default'];
- var precisionFactor = Math.pow(10, this.precision);
+ return mask.replace(token, function ($0) {
+ return $0 in formatFlags ? formatFlags[$0](dateObj, i18n) : $0.slice(1, $0.length - 1);
+ });
+ };
- return this.toPrecision((precisionFactor * val + precisionFactor * step) / precisionFactor);
- },
- _decrease: function _decrease(val, step) {
- if (typeof val !== 'number') return this.currentValue;
+ /**
+ * Parse a date string into an object, changes - into /
+ * @method parse
+ * @param {string} dateStr Date string
+ * @param {string} format Date parse format
+ * @returns {Date|boolean}
+ */
+ fecha.parse = function (dateStr, format, i18nSettings) {
+ var i18n = i18nSettings || fecha.i18n;
- var precisionFactor = Math.pow(10, this.precision);
+ if (typeof format !== 'string') {
+ throw new Error('Invalid format in fecha.parse');
+ }
- return this.toPrecision((precisionFactor * val - precisionFactor * step) / precisionFactor);
- },
- increase: function increase() {
- if (this.disabled || this.maxDisabled) return;
- var value = this.value || 0;
- var newVal = this._increase(value, this.step);
- if (newVal > this.max) return;
- this.setCurrentValue(newVal);
- },
- decrease: function decrease() {
- if (this.disabled || this.minDisabled) return;
- var value = this.value || 0;
- var newVal = this._decrease(value, this.step);
- if (newVal < this.min) return;
- this.setCurrentValue(newVal);
- },
- handleBlur: function handleBlur() {
- this.$refs.input.setCurrentValue(this.currentValue);
- },
- setCurrentValue: function setCurrentValue(newVal) {
- var oldVal = this.currentValue;
- if (newVal >= this.max) newVal = this.max;
- if (newVal <= this.min) newVal = this.min;
- if (oldVal === newVal) {
- this.$refs.input.setCurrentValue(this.currentValue);
- return;
- }
- this.$emit('change', newVal, oldVal);
- this.$emit('input', newVal);
- this.currentValue = newVal;
- },
- handleInput: function handleInput(value) {
- if (value === '') {
- return;
- }
- var newVal = Number(value);
- if (!isNaN(newVal)) {
- this.setCurrentValue(newVal);
- } else {
- this.$refs.input.setCurrentValue(this.currentValue);
- }
- }
- },
- created: function created() {
- var _this = this;
+ format = fecha.masks[format] || format;
- this.debounceHandleInput = (0, _debounce2.default)(this.debounce, function (value) {
- _this.handleInput(value);
- });
- }
- }; //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+ // Avoid regular expression denial of service, fail early for really long strings
+ // https://www.owasp.org/index.php/Regular_expression_Denial_of_Service_-_ReDoS
+ if (dateStr.length > 1000) {
+ return false;
+ }
-/***/ },
+ var isValid = true;
+ var dateInfo = {};
+ format.replace(token, function ($0) {
+ if (parseFlags[$0]) {
+ var info = parseFlags[$0];
+ var index = dateStr.search(info[0]);
+ if (!~index) {
+ isValid = false;
+ } else {
+ dateStr.replace(info[0], function (result) {
+ info[1](dateInfo, result, i18n);
+ dateStr = dateStr.substr(index + result.length);
+ return result;
+ });
+ }
+ }
-/***/ 175:
-/***/ function(module, exports) {
+ return parseFlags[$0] ? '' : $0.slice(1, $0.length - 1);
+ });
- module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;
- return _c('div', {
- staticClass: "el-input-number",
- class: [
- _vm.size ? 'el-input-number--' + _vm.size : '', {
- 'is-disabled': _vm.disabled
- }, {
- 'is-without-controls': !_vm.controls
- }
- ]
- }, [(_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
- }
- }, [_c('i', {
- staticClass: "el-icon-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
- }
- }, [_c('i', {
- staticClass: "el-icon-plus"
- })]) : _vm._e(), _c('el-input', {
- ref: "input",
- attrs: {
- "value": _vm.currentValue,
- "disabled": _vm.disabled,
- "size": _vm.size,
- "max": _vm.max,
- "min": _vm.min
- },
- on: {
- "blur": _vm.handleBlur,
- "input": _vm.debounceHandleInput
- },
- nativeOn: {
- "keydown": [function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "up", 38)) { return null; }
- $event.preventDefault();
- _vm.increase($event)
- }, function($event) {
- if (!('button' in $event) && _vm._k($event.keyCode, "down", 40)) { return null; }
- $event.preventDefault();
- _vm.decrease($event)
- }]
- }
- }, [(_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()], 2)], 1)
- },staticRenderFns: []}
+ if (!isValid) {
+ return false;
+ }
-/***/ }
+ var today = new Date();
+ if (dateInfo.isPm === true && dateInfo.hour != null && +dateInfo.hour !== 12) {
+ dateInfo.hour = +dateInfo.hour + 12;
+ } else if (dateInfo.isPm === false && +dateInfo.hour === 12) {
+ dateInfo.hour = 0;
+ }
-/******/ });
+ var date;
+ if (dateInfo.timezoneOffset != null) {
+ dateInfo.minute = +(dateInfo.minute || 0) - +dateInfo.timezoneOffset;
+ date = new Date(Date.UTC(dateInfo.year || today.getFullYear(), dateInfo.month || 0, dateInfo.day || 1, dateInfo.hour || 0, dateInfo.minute || 0, dateInfo.second || 0, dateInfo.millisecond || 0));
+ } else {
+ date = new Date(dateInfo.year || today.getFullYear(), dateInfo.month || 0, dateInfo.day || 1, dateInfo.hour || 0, dateInfo.minute || 0, dateInfo.second || 0, dateInfo.millisecond || 0);
+ }
+ return date;
+ };
+
+ /* istanbul ignore next */
+ if (typeof module !== 'undefined' && module.exports) {
+ module.exports = fecha;
+ } else if (true) {
+ !(__WEBPACK_AMD_DEFINE_RESULT__ = function () {
+ return fecha;
+ }.call(exports, __webpack_require__, exports, module),
+ __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
+ } else {
+ main.fecha = fecha;
+ }
+})(undefined);
/***/ }),
-/* 77 */
-/***/ (function(module, exports) {
+/* 56 */
+/***/ (function(module, exports, __webpack_require__) {
-module.exports =
-/******/ (function(modules) { // webpackBootstrap
-/******/ // The module cache
-/******/ var installedModules = {};
+"use strict";
-/******/ // The require function
-/******/ function __webpack_require__(moduleId) {
-/******/ // Check if module is in cache
-/******/ if(installedModules[moduleId])
-/******/ return installedModules[moduleId].exports;
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
-/******/ // Create a new module (and put it into the cache)
-/******/ var module = installedModules[moduleId] = {
-/******/ exports: {},
-/******/ id: moduleId,
-/******/ loaded: false
-/******/ };
+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; };
-/******/ // Execute the module function
-/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
+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; };
-/******/ // Flag the module as loaded
-/******/ module.loaded = true;
+var _util = __webpack_require__(0);
-/******/ // Return the exports of the module
-/******/ return module.exports;
-/******/ }
+var _validator = __webpack_require__(57);
+var _validator2 = _interopRequireDefault(_validator);
-/******/ // expose the modules object (__webpack_modules__)
-/******/ __webpack_require__.m = modules;
+var _messages2 = __webpack_require__(76);
-/******/ // expose the module cache
-/******/ __webpack_require__.c = installedModules;
+var _rule = __webpack_require__(1);
-/******/ // __webpack_public_path__
-/******/ __webpack_require__.p = "/dist/";
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-/******/ // Load entry module and return exports
-/******/ return __webpack_require__(0);
-/******/ })
-/************************************************************************/
-/******/ ({
+/**
+ * Encapsulates a validation schema.
+ *
+ * @param descriptor An object declaring validation rules
+ * for this schema.
+ */
+function Schema(descriptor) {
+ this.rules = null;
+ this._messages = _messages2.messages;
+ this.define(descriptor);
+}
-/***/ 0:
-/***/ function(module, exports, __webpack_require__) {
+Schema.prototype = {
+ messages: function messages(_messages) {
+ if (_messages) {
+ this._messages = (0, _util.deepMerge)((0, _messages2.newMessages)(), _messages);
+ }
+ return this._messages;
+ },
+ define: function define(rules) {
+ if (!rules) {
+ throw new Error('Cannot configure a schema with no rules');
+ }
+ if ((typeof rules === 'undefined' ? 'undefined' : _typeof(rules)) !== 'object' || Array.isArray(rules)) {
+ throw new Error('Rules must be an object');
+ }
+ this.rules = {};
+ var z = void 0;
+ var item = void 0;
+ for (z in rules) {
+ if (rules.hasOwnProperty(z)) {
+ item = rules[z];
+ this.rules[z] = Array.isArray(item) ? item : [item];
+ }
+ }
+ },
+ validate: function validate(source_) {
+ var _this = this;
- module.exports = __webpack_require__(237);
+ var o = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var oc = arguments[2];
+ var source = source_;
+ var options = o;
+ var callback = oc;
+ if (typeof options === 'function') {
+ callback = options;
+ options = {};
+ }
+ if (!this.rules || Object.keys(this.rules).length === 0) {
+ if (callback) {
+ callback();
+ }
+ return;
+ }
+ function complete(results) {
+ var i = void 0;
+ var field = void 0;
+ var errors = [];
+ var fields = {};
-/***/ },
+ function add(e) {
+ if (Array.isArray(e)) {
+ errors = errors.concat.apply(errors, e);
+ } else {
+ errors.push(e);
+ }
+ }
-/***/ 3:
-/***/ function(module, exports) {
+ for (i = 0; i < results.length; i++) {
+ add(results[i]);
+ }
+ if (!errors.length) {
+ errors = null;
+ fields = null;
+ } else {
+ for (i = 0; i < errors.length; i++) {
+ field = errors[i].field;
+ fields[field] = fields[field] || [];
+ fields[field].push(errors[i]);
+ }
+ }
+ callback(errors, fields);
+ }
- /* globals __VUE_SSR_CONTEXT__ */
+ if (options.messages) {
+ var messages = this.messages();
+ if (messages === _messages2.messages) {
+ messages = (0, _messages2.newMessages)();
+ }
+ (0, _util.deepMerge)(messages, options.messages);
+ options.messages = messages;
+ } else {
+ options.messages = this.messages();
+ }
- // this module is a runtime utility for cleaner component module output and will
- // be included in the final webpack user bundle
+ options.error = _rule.error;
+ var arr = void 0;
+ var value = void 0;
+ var series = {};
+ var keys = options.keys || Object.keys(this.rules);
+ keys.forEach(function (z) {
+ arr = _this.rules[z];
+ value = source[z];
+ arr.forEach(function (r) {
+ var rule = r;
+ if (typeof rule.transform === 'function') {
+ if (source === source_) {
+ source = _extends({}, source);
+ }
+ value = source[z] = rule.transform(value);
+ }
+ if (typeof rule === 'function') {
+ rule = {
+ validator: rule
+ };
+ } else {
+ rule = _extends({}, rule);
+ }
+ rule.validator = _this.getValidationMethod(rule);
+ rule.field = z;
+ rule.fullField = rule.fullField || z;
+ rule.type = _this.getType(rule);
+ if (!rule.validator) {
+ return;
+ }
+ series[z] = series[z] || [];
+ series[z].push({
+ rule: rule,
+ value: value,
+ source: source,
+ field: z
+ });
+ });
+ });
+ var errorFields = {};
+ (0, _util.asyncMap)(series, options, function (data, doIt) {
+ var rule = data.rule;
+ var deep = (rule.type === 'object' || rule.type === 'array') && (_typeof(rule.fields) === 'object' || _typeof(rule.defaultField) === 'object');
+ deep = deep && (rule.required || !rule.required && data.value);
+ rule.field = data.field;
+ function addFullfield(key, schema) {
+ return _extends({}, schema, {
+ fullField: rule.fullField + '.' + key
+ });
+ }
- module.exports = function normalizeComponent (
- rawScriptExports,
- compiledTemplate,
- injectStyles,
- scopeId,
- moduleIdentifier /* server only */
- ) {
- var esModule
- var scriptExports = rawScriptExports = rawScriptExports || {}
+ function cb() {
+ var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
+
+ var errors = e;
+ if (!Array.isArray(errors)) {
+ errors = [errors];
+ }
+ if (errors.length) {
+ (0, _util.warning)('async-validator:', errors);
+ }
+ if (errors.length && rule.message) {
+ errors = [].concat(rule.message);
+ }
+
+ errors = errors.map((0, _util.complementError)(rule));
+
+ if ((options.first || options.fieldFirst) && errors.length) {
+ errorFields[rule.field] = 1;
+ return doIt(errors);
+ }
+ if (!deep) {
+ doIt(errors);
+ } else {
+ // if rule is required but the target object
+ // does not exist fail at the rule level and don't
+ // go deeper
+ if (rule.required && !data.value) {
+ if (rule.message) {
+ errors = [].concat(rule.message).map((0, _util.complementError)(rule));
+ } else {
+ errors = [options.error(rule, (0, _util.format)(options.messages.required, rule.field))];
+ }
+ return doIt(errors);
+ }
+
+ var fieldsSchema = {};
+ if (rule.defaultField) {
+ for (var k in data.value) {
+ if (data.value.hasOwnProperty(k)) {
+ fieldsSchema[k] = rule.defaultField;
+ }
+ }
+ }
+ fieldsSchema = _extends({}, fieldsSchema, data.rule.fields);
+ for (var f in fieldsSchema) {
+ if (fieldsSchema.hasOwnProperty(f)) {
+ var fieldSchema = Array.isArray(fieldsSchema[f]) ? fieldsSchema[f] : [fieldsSchema[f]];
+ fieldsSchema[f] = fieldSchema.map(addFullfield.bind(null, f));
+ }
+ }
+ var schema = new Schema(fieldsSchema);
+ schema.messages(options.messages);
+ if (data.rule.options) {
+ data.rule.options.messages = options.messages;
+ data.rule.options.error = options.error;
+ }
+ schema.validate(data.value, data.rule.options || options, function (errs) {
+ doIt(errs && errs.length ? errors.concat(errs) : errs);
+ });
+ }
+ }
- // ES6 modules interop
- var type = typeof rawScriptExports.default
- if (type === 'object' || type === 'function') {
- esModule = rawScriptExports
- scriptExports = rawScriptExports.default
- }
+ rule.validator(rule, data.value, cb, data.source, options);
+ }, function (results) {
+ complete(results);
+ });
+ },
+ getType: function getType(rule) {
+ if (rule.type === undefined && rule.pattern instanceof RegExp) {
+ rule.type = 'pattern';
+ }
+ if (typeof rule.validator !== 'function' && rule.type && !_validator2["default"].hasOwnProperty(rule.type)) {
+ throw new Error((0, _util.format)('Unknown rule type %s', rule.type));
+ }
+ return rule.type || 'string';
+ },
+ getValidationMethod: function getValidationMethod(rule) {
+ if (typeof rule.validator === 'function') {
+ return rule.validator;
+ }
+ var keys = Object.keys(rule);
+ var messageIndex = keys.indexOf('message');
+ if (messageIndex !== -1) {
+ keys.splice(messageIndex, 1);
+ }
+ if (keys.length === 1 && keys[0] === 'required') {
+ return _validator2["default"].required;
+ }
+ return _validator2["default"][this.getType(rule)] || false;
+ }
+};
- // Vue.extend constructor export interop
- var options = typeof scriptExports === 'function'
- ? scriptExports.options
- : scriptExports
+Schema.register = function register(type, validator) {
+ if (typeof validator !== 'function') {
+ throw new Error('Cannot register a validator by type, validator is not a function');
+ }
+ _validator2["default"][type] = validator;
+};
- // render functions
- if (compiledTemplate) {
- options.render = compiledTemplate.render
- options.staticRenderFns = compiledTemplate.staticRenderFns
- }
+Schema.messages = _messages2.messages;
- // scopedId
- if (scopeId) {
- options._scopeId = scopeId
- }
+exports["default"] = Schema;
+module.exports = exports['default'];
- var hook
- if (moduleIdentifier) { // server build
- hook = function (context) {
- // 2.3 injection
- context = context || (this.$vnode && this.$vnode.ssrContext)
- // 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 = injectStyles
- }
+/***/ }),
+/* 57 */
+/***/ (function(module, exports, __webpack_require__) {
- if (hook) {
- // inject component registration as beforeCreate hook
- var existing = options.beforeCreate
- options.beforeCreate = existing
- ? [].concat(existing, hook)
- : [hook]
- }
+"use strict";
- return {
- esModule: esModule,
- exports: scriptExports,
- options: options
- }
- }
+module.exports = {
+ string: __webpack_require__(58),
+ method: __webpack_require__(64),
+ number: __webpack_require__(65),
+ "boolean": __webpack_require__(66),
+ regexp: __webpack_require__(67),
+ integer: __webpack_require__(68),
+ "float": __webpack_require__(69),
+ array: __webpack_require__(70),
+ object: __webpack_require__(71),
+ "enum": __webpack_require__(72),
+ pattern: __webpack_require__(73),
+ email: __webpack_require__(17),
+ url: __webpack_require__(17),
+ date: __webpack_require__(74),
+ hex: __webpack_require__(17),
+ required: __webpack_require__(75)
+};
-/***/ },
+/***/ }),
+/* 58 */
+/***/ (function(module, exports, __webpack_require__) {
-/***/ 237:
-/***/ function(module, exports, __webpack_require__) {
+"use strict";
- 'use strict';
- exports.__esModule = true;
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
- var _progress = __webpack_require__(238);
+var _rule = __webpack_require__(1);
- var _progress2 = _interopRequireDefault(_progress);
+var _rule2 = _interopRequireDefault(_rule);
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+var _util = __webpack_require__(0);
- /* istanbul ignore next */
- _progress2.default.install = function (Vue) {
- Vue.component(_progress2.default.name, _progress2.default);
- };
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
- exports.default = _progress2.default;
+/**
+ * Performs validation for string types.
+ *
+ * @param rule The validation rule.
+ * @param value The value of the field on the source object.
+ * @param callback The callback function.
+ * @param source The source object being validated.
+ * @param options The validation options.
+ * @param options.messages The validation messages.
+ */
+function string(rule, value, callback, source, options) {
+ var errors = [];
+ var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);
+ if (validate) {
+ if ((0, _util.isEmptyValue)(value, 'string') && !rule.required) {
+ return callback();
+ }
+ _rule2["default"].required(rule, value, source, errors, options, 'string');
+ if (!(0, _util.isEmptyValue)(value, 'string')) {
+ _rule2["default"].type(rule, value, source, errors, options);
+ _rule2["default"].range(rule, value, source, errors, options);
+ _rule2["default"].pattern(rule, value, source, errors, options);
+ if (rule.whitespace === true) {
+ _rule2["default"].whitespace(rule, value, source, errors, options);
+ }
+ }
+ }
+ callback(errors);
+}
-/***/ },
+exports["default"] = string;
+module.exports = exports['default'];
-/***/ 238:
-/***/ function(module, exports, __webpack_require__) {
+/***/ }),
+/* 59 */
+/***/ (function(module, exports, __webpack_require__) {
- var Component = __webpack_require__(3)(
- /* script */
- __webpack_require__(239),
- /* template */
- __webpack_require__(240),
- /* styles */
- null,
- /* scopeId */
- null,
- /* moduleIdentifier (server only) */
- null
- )
+"use strict";
- module.exports = Component.exports
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
-/***/ },
+var _util = __webpack_require__(0);
-/***/ 239:
-/***/ function(module, exports) {
+var util = _interopRequireWildcard(_util);
- 'use strict';
+function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj["default"] = obj; return newObj; } }
- exports.__esModule = true;
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
- //
+/**
+ * Rule for validating whitespace.
+ *
+ * @param rule The validation rule.
+ * @param value The value of the field on the source object.
+ * @param source The source object being validated.
+ * @param errors An array of errors that this rule may add
+ * validation errors to.
+ * @param options The validation options.
+ * @param options.messages The validation messages.
+ */
+function whitespace(rule, value, source, errors, options) {
+ if (/^\s+$/.test(value) || value === '') {
+ errors.push(util.format(options.messages.whitespace, rule.fullField));
+ }
+}
- exports.default = {
- name: 'ElProgress',
- props: {
- type: {
- type: String,
- default: 'line',
- validator: function validator(val) {
- return ['line', 'circle'].indexOf(val) > -1;
- }
- },
- percentage: {
- type: Number,
- default: 0,
- required: true,
- validator: function validator(val) {
- return val >= 0 && val <= 100;
- }
- },
- status: {
- type: String
- },
- strokeWidth: {
- type: Number,
- default: 6
- },
- textInside: {
- type: Boolean,
- default: false
- },
- width: {
- type: Number,
- default: 126
- },
- showText: {
- type: Boolean,
- default: true
- }
- },
- computed: {
- barStyle: function barStyle() {
- var style = {};
- style.width = this.percentage + '%';
- return style;
- },
- relativeStrokeWidth: function relativeStrokeWidth() {
- return (this.strokeWidth / this.width * 100).toFixed(1);
- },
- trackPath: function trackPath() {
- var radius = parseInt(50 - parseFloat(this.relativeStrokeWidth) / 2, 10);
+exports["default"] = whitespace;
+module.exports = exports['default'];
- return 'M 50 50 m 0 -' + radius + ' a ' + radius + ' ' + radius + ' 0 1 1 0 ' + radius * 2 + ' a ' + radius + ' ' + radius + ' 0 1 1 0 -' + radius * 2;
- },
- perimeter: function perimeter() {
- var radius = 50 - parseFloat(this.relativeStrokeWidth) / 2;
- return 2 * Math.PI * radius;
- },
- circlePathStyle: function circlePathStyle() {
- var perimeter = this.perimeter;
- return {
- strokeDasharray: perimeter + 'px,' + perimeter + 'px',
- strokeDashoffset: (1 - this.percentage / 100) * perimeter + 'px',
- transition: 'stroke-dashoffset 0.6s ease 0s, stroke 0.6s ease'
- };
- },
- stroke: function stroke() {
- var ret;
- switch (this.status) {
- case 'success':
- ret = '#13ce66';
- break;
- case 'exception':
- ret = '#ff4949';
- break;
- default:
- ret = '#20a0ff';
- }
- return ret;
- },
- iconClass: function iconClass() {
- if (this.type === 'line') {
- return this.status === 'success' ? 'el-icon-circle-check' : 'el-icon-circle-cross';
- } 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;
- }
- }
- };
+/***/ }),
+/* 60 */
+/***/ (function(module, exports, __webpack_require__) {
-/***/ },
+"use strict";
-/***/ 240:
-/***/ function(module, exports) {
- module.exports={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,
- }
- ]
- }, [(_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.percentage) + "%")]) : _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",
- 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-linecap": "round",
- "stroke": _vm.stroke,
- "stroke-width": _vm.relativeStrokeWidth,
- "fill": "none"
- }
- })])]), (_vm.showText && !_vm.textInside) ? _c('div', {
- staticClass: "el-progress__text",
- style: ({
- fontSize: _vm.progressTextSize + 'px'
- })
- }, [(!_vm.status) ? [_vm._v(_vm._s(_vm.percentage) + "%")] : _c('i', {
- class: _vm.iconClass
- })], 2) : _vm._e()])
- },staticRenderFns: []}
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
-/***/ }
+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; };
-/******/ });
+var _util = __webpack_require__(0);
-/***/ }),
-/* 78 */
-/***/ (function(module, exports, __webpack_require__) {
+var util = _interopRequireWildcard(_util);
-"use strict";
+var _required = __webpack_require__(28);
+var _required2 = _interopRequireDefault(_required);
-exports.__esModule = true;
-/**
- * Show migrating guide in browser console.
- *
- * Usage:
- * import Migrating from 'element-ui/src/mixins/migrating';
- *
- * mixins: [Migrating]
- *
- * add getMigratingConfig method for your component.
- * getMigratingConfig() {
- * return {
- * props: {
- * 'allow-no-selection': 'allow-no-selection is removed.',
- * 'selection-mode': 'selection-mode is removed.'
- * },
- * events: {
- * selectionchange: 'selectionchange is renamed to selection-change.'
- * }
- * };
- * },
- */
-exports.default = {
- mounted: function mounted() {
- if (false) return;
- if (!this.$vnode) return;
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
- var _getMigratingConfig = this.getMigratingConfig(),
- props = _getMigratingConfig.props,
- events = _getMigratingConfig.events;
+function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj["default"] = obj; return newObj; } }
- var _$vnode = this.$vnode,
- data = _$vnode.data,
- componentOptions = _$vnode.componentOptions;
+/* eslint max-len:0 */
- var definedProps = data.attrs || {};
- var definedEvents = componentOptions.listeners || {};
+var pattern = {
+ // http://emailregex.com/
+ email: /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,
+ url: new RegExp('^(?!mailto:)(?:(?:http|https|ftp)://|//)(?:\\S+(?::\\S*)?@)?(?:(?:(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}(?:\\.(?:[0-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))|(?:(?:[a-z\\u00a1-\\uffff0-9]+-?)*[a-z\\u00a1-\\uffff0-9]+)(?:\\.(?:[a-z\\u00a1-\\uffff0-9]+-?)*[a-z\\u00a1-\\uffff0-9]+)*(?:\\.(?:[a-z\\u00a1-\\uffff]{2,})))|localhost)(?::\\d{2,5})?(?:(/|\\?|#)[^\\s]*)?$', 'i'),
+ hex: /^#?([a-f0-9]{6}|[a-f0-9]{3})$/i
+};
- for (var propName in definedProps) {
- if (definedProps.hasOwnProperty(propName) && props[propName]) {
- console.warn('[Element Migrating][Attribute]: ' + props[propName]);
- }
+var types = {
+ integer: function integer(value) {
+ return types.number(value) && parseInt(value, 10) === value;
+ },
+ "float": function float(value) {
+ return types.number(value) && !types.integer(value);
+ },
+ array: function array(value) {
+ return Array.isArray(value);
+ },
+ regexp: function regexp(value) {
+ if (value instanceof RegExp) {
+ return true;
}
-
- for (var eventName in definedEvents) {
- if (definedEvents.hasOwnProperty(eventName) && events[eventName]) {
- console.warn('[Element Migrating][Event]: ' + events[eventName]);
- }
+ try {
+ return !!new RegExp(value);
+ } catch (e) {
+ return false;
+ }
+ },
+ date: function date(value) {
+ return typeof value.getTime === 'function' && typeof value.getMonth === 'function' && typeof value.getYear === 'function';
+ },
+ number: function number(value) {
+ if (isNaN(value)) {
+ return false;
}
+ return typeof value === 'number';
+ },
+ object: function object(value) {
+ return (typeof value === 'undefined' ? 'undefined' : _typeof(value)) === 'object' && !types.array(value);
+ },
+ method: function method(value) {
+ return typeof value === 'function';
+ },
+ email: function email(value) {
+ return typeof value === 'string' && !!value.match(pattern.email);
},
-
- methods: {
- getMigratingConfig: function getMigratingConfig() {
- return {
- props: {},
- events: {}
- };
- }
+ url: function url(value) {
+ return typeof value === 'string' && !!value.match(pattern.url);
+ },
+ hex: function hex(value) {
+ return typeof value === 'string' && !!value.match(pattern.hex);
}
};
-/***/ }),
-/* 79 */
-/***/ (function(module, exports) {
-
-var nestRE = /^(attrs|props|on|nativeOn|class|style|hook)$/
-
-module.exports = function mergeJSXProps (objs) {
- return objs.reduce(function (a, b) {
- var aa, bb, key, nestedKey, temp
- for (key in b) {
- aa = a[key]
- bb = b[key]
- if (aa && nestRE.test(key)) {
- // normalize class
- if (key === 'class') {
- if (typeof aa === 'string') {
- temp = aa
- a[key] = aa = {}
- aa[temp] = true
- }
- if (typeof bb === 'string') {
- temp = bb
- b[key] = bb = {}
- bb[temp] = true
- }
- }
- if (key === 'on' || key === 'nativeOn' || key === 'hook') {
- // merge functions
- for (nestedKey in bb) {
- aa[nestedKey] = mergeFn(aa[nestedKey], bb[nestedKey])
- }
- } else if (Array.isArray(aa)) {
- a[key] = aa.concat(bb)
- } else if (Array.isArray(bb)) {
- a[key] = [aa].concat(bb)
- } else {
- for (nestedKey in bb) {
- aa[nestedKey] = bb[nestedKey]
- }
- }
- } else {
- a[key] = b[key]
- }
+/**
+ * Rule for validating the type of a value.
+ *
+ * @param rule The validation rule.
+ * @param value The value of the field on the source object.
+ * @param source The source object being validated.
+ * @param errors An array of errors that this rule may add
+ * validation errors to.
+ * @param options The validation options.
+ * @param options.messages The validation messages.
+ */
+function type(rule, value, source, errors, options) {
+ if (rule.required && value === undefined) {
+ (0, _required2["default"])(rule, value, source, errors, options);
+ return;
+ }
+ var custom = ['integer', 'float', 'array', 'regexp', 'object', 'method', 'email', 'number', 'date', 'url', 'hex'];
+ var ruleType = rule.type;
+ if (custom.indexOf(ruleType) > -1) {
+ if (!types[ruleType](value)) {
+ errors.push(util.format(options.messages.types[ruleType], rule.fullField, rule.type));
}
- return a
- }, {})
-}
-
-function mergeFn (a, b) {
- return function () {
- a.apply(this, arguments)
- b.apply(this, arguments)
+ // straight typeof check
+ } else if (ruleType && (typeof value === 'undefined' ? 'undefined' : _typeof(value)) !== rule.type) {
+ errors.push(util.format(options.messages.types[ruleType], rule.fullField, rule.type));
}
}
+exports["default"] = type;
+module.exports = exports['default'];
/***/ }),
-/* 80 */
+/* 61 */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
-exports.__esModule = true;
-exports.isDef = isDef;
-function isDef(val) {
- return val !== undefined && val !== null;
-}
-
-/***/ }),
-/* 81 */
-/***/ (function(module, exports, __webpack_require__) {
-
-!function(e,t){ true?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.DataTables=t():e.DataTables=t()}(this,function(){return function(e){function t(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return e[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};return t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="/",t(t.s=17)}([function(e,t){var n=e.exports={version:"2.4.0"};"number"==typeof __e&&(__e=n)},function(e,t){e.exports=function(e){try{return!!e()}catch(e){return!0}}},function(e,t,n){e.exports=!n(1)(function(){return 7!=Object.defineProperty({},"a",{get:function(){return 7}}).a})},function(e,t){var n=e.exports="undefined"!=typeof window&&window.Math==Math?window:"undefined"!=typeof self&&self.Math==Math?self:Function("return this")();"number"==typeof __g&&(__g=n)},function(e,t){e.exports=function(e){return"object"==typeof e?null!==e:"function"==typeof e}},function(e,t){e.exports=function(e){if(void 0==e)throw TypeError("Can't call method on "+e);return e}},function(e,t,n){var r=n(3),o=n(0),i=n(28),a=n(32),c=function(e,t,n){var s,u,f,l=e&c.F,p=e&c.G,h=e&c.S,d=e&c.P,v=e&c.B,g=e&c.W,b=p?o:o[t]||(o[t]={}),y=b.prototype,m=p?r:h?r[t]:(r[t]||{}).prototype;p&&(n=t);for(s in n)(u=!l&&m&&void 0!==m[s])&&s in b||(f=u?m[s]:n[s],b[s]=p&&"function"!=typeof m[s]?n[s]:v&&u?i(f,r):g&&m[s]==f?function(e){var t=function(t,n,r){if(this instanceof e){switch(arguments.length){case 0:return new e;case 1:return new e(t);case 2:return new e(t,n)}return new e(t,n,r)}return e.apply(this,arguments)};return t.prototype=e.prototype,t}(f):d&&"function"==typeof f?i(Function.call,f):f,d&&((b.virtual||(b.virtual={}))[s]=f,e&c.R&&y&&!y[s]&&a(y,s,f)))};c.F=1,c.G=2,c.S=4,c.P=8,c.B=16,c.W=32,c.U=64,c.R=128,e.exports=c},function(e,t,n){var r=n(27);e.exports=Object("z").propertyIsEnumerable(0)?Object:function(e){return"String"==r(e)?e.split(""):Object(e)}},function(e,t,n){var r=n(37),o=n(30);e.exports=Object.keys||function(e){return r(e,o)}},function(e,t){var n=Math.ceil,r=Math.floor;e.exports=function(e){return isNaN(e=+e)?0:(e>0?r:n)(e)}},function(e,t,n){var r=n(7),o=n(5);e.exports=function(e){return r(o(e))}},function(e,t,n){var r=n(5);e.exports=function(e){return Object(r(e))}},function(e,t){function n(e,t){var n=e[1]||"",o=e[3];if(!o)return n;if(t&&"function"==typeof btoa){var i=r(o);return[n].concat(o.sources.map(function(e){return"/*# sourceURL="+o.sourceRoot+e+" */"})).concat([i]).join("\n")}return[n].join("\n")}function r(e){return"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(e))))+" */"}e.exports=function(e){var t=[];return t.toString=function(){return this.map(function(t){var r=n(t,e);return t[2]?"@media "+t[2]+"{"+r+"}":r}).join("")},t.i=function(e,n){"string"==typeof e&&(e=[[null,e,""]]);for(var r={},o=0;on.parts.length&&(r.parts.length=n.parts.length)}else{for(var a=[],o=0;o0},innerColNotRowClick:function(){return this.colNotRowClick.concat([this.actionColProp])},innerCustomFilters:function(){var e=this,t=this.formatToArray(this.customFilters),n=[];return t.forEach(function(t){var r=a()({},t);r={props:e.formatProps(r.props),vals:e.formatToArray(t.vals)},n.push(r)}),n},innerTableProps:function(){return a()({border:!0,stripe:!0,fit:!0},this.tableProps)},sortedData:function(){var e=this.data.slice();if(this.sortData.order){var t=this.sortData.order,n=this.sortData.prop,r="descending"===t;e.sort(function(e,t){return e[n]>t[n]?1:e[n]-1})})},e)}),this.$emit("filtered-data",e),e},curTableData:function(){var e=this.innerPageSize*(this.currentPage-1),t=e+this.innerPageSize;return this.tableData.slice(e,t)},total:function(){return this.tableData.length},checkboxShow:function(){return this.innerCheckboxFilterDef.def.length>0},searchShow:function(){return!1!==this.innerSearchDef.show},actionsShow:function(){return this.innerActionsDef.def.length>0},paginationShow:function(){return!1!==this.paginationDef.show},filters:function(){var e=this.formatToArray(this.innerCustomFilters);return this.searchShow&&e.push({props:this.formatProps(this.innerSearchDef.props),vals:this.formatToArray(this.innerSearchKey),filterFunction:this.innerSearchDef.filterFunction}),this.checkboxShow&&e.push({props:this.formatProps(this.innerCheckboxFilterDef.props),vals:this.checkedFilters,filterFunction:this.innerCheckboxFilterDef.filterFunction}),e},updateInnerSearchKey:function(){var e=this,t=this.innerSearchDef.debounceTime;return l()(function(t){e.innerSearchKey=e.searchKey},t)}},methods:{formatProps:function(e){return e?[].concat(e):void 0},formatToArray:function(e){return e?[].concat(e):[]},handleSort:function(e){this.sortData=e,this.innerTableProps.defaultSort={prop:e.prop,order:e.order}},handleSizeChange:function(e){this.innerPageSize=e,this.$emit("size-change",e)},handleCurrentChange:function(e){this.currentPage=e,this.$emit("current-change",e)},handleFilterChange:function(e){this.checkedFilters=e}},watch:{innerPaginationDef:{immediate:!0,handler:function(e){this.innerPageSize=e.pageSize,this.currentPage=e.currentPage}},searchKey:function(){this.updateInnerSearchKey()},data:{immediate:!0,handler:function(e){this._allDataProps=o()(e&&e[0]||{})}}}}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default={props:{checks:[Array]},data:function(){return{checkList:[]}},methods:{changeHandler:function(){this.$emit("checkChange",this.checkList)}}}},function(e,t,n){e.exports={default:n(22),__esModule:!0}},function(e,t,n){e.exports={default:n(23),__esModule:!0}},function(e,t,n){n(47),e.exports=n(0).Object.assign},function(e,t,n){n(48),e.exports=n(0).Object.keys},function(e,t){e.exports=function(e){if("function"!=typeof e)throw TypeError(e+" is not a function!");return e}},function(e,t,n){var r=n(4);e.exports=function(e){if(!r(e))throw TypeError(e+" is not an object!");return e}},function(e,t,n){var r=n(10),o=n(44),i=n(43);e.exports=function(e){return function(t,n,a){var c,s=r(t),u=o(s.length),f=i(a,u);if(e&&n!=n){for(;u>f;)if((c=s[f++])!=c)return!0}else for(;u>f;f++)if((e||f in s)&&s[f]===n)return e||f||0;return!e&&-1}}},function(e,t){var n={}.toString;e.exports=function(e){return n.call(e).slice(8,-1)}},function(e,t,n){var r=n(24);e.exports=function(e,t,n){if(r(e),void 0===t)return e;switch(n){case 1:return function(n){return e.call(t,n)};case 2:return function(n,r){return e.call(t,n,r)};case 3:return function(n,r,o){return e.call(t,n,r,o)}}return function(){return e.apply(t,arguments)}}},function(e,t,n){var r=n(4),o=n(3).document,i=r(o)&&r(o.createElement);e.exports=function(e){return i?o.createElement(e):{}}},function(e,t){e.exports="constructor,hasOwnProperty,isPrototypeOf,propertyIsEnumerable,toLocaleString,toString,valueOf".split(",")},function(e,t){var n={}.hasOwnProperty;e.exports=function(e,t){return n.call(e,t)}},function(e,t,n){var r=n(35),o=n(40);e.exports=n(2)?function(e,t,n){return r.f(e,t,o(1,n))}:function(e,t,n){return e[t]=n,e}},function(e,t,n){e.exports=!n(2)&&!n(1)(function(){return 7!=Object.defineProperty(n(29)("div"),"a",{get:function(){return 7}}).a})},function(e,t,n){"use strict";var r=n(8),o=n(36),i=n(38),a=n(11),c=n(7),s=Object.assign;e.exports=!s||n(1)(function(){var e={},t={},n=Symbol(),r="abcdefghijklmnopqrst";return e[n]=7,r.split("").forEach(function(e){t[e]=e}),7!=s({},e)[n]||Object.keys(s({},t)).join("")!=r})?function(e,t){for(var n=a(e),s=arguments.length,u=1,f=o.f,l=i.f;s>u;)for(var p,h=c(arguments[u++]),d=f?r(h).concat(f(h)):r(h),v=d.length,g=0;v>g;)l.call(h,p=d[g++])&&(n[p]=h[p]);return n}:s},function(e,t,n){var r=n(25),o=n(33),i=n(45),a=Object.defineProperty;t.f=n(2)?Object.defineProperty:function(e,t,n){if(r(e),t=i(t,!0),r(n),o)try{return a(e,t,n)}catch(e){}if("get"in n||"set"in n)throw TypeError("Accessors not supported!");return"value"in n&&(e[t]=n.value),e}},function(e,t){t.f=Object.getOwnPropertySymbols},function(e,t,n){var r=n(31),o=n(10),i=n(26)(!1),a=n(41)("IE_PROTO");e.exports=function(e,t){var n,c=o(e),s=0,u=[];for(n in c)n!=a&&r(c,n)&&u.push(n);for(;t.length>s;)r(c,n=t[s++])&&(~i(u,n)||u.push(n));return u}},function(e,t){t.f={}.propertyIsEnumerable},function(e,t,n){var r=n(6),o=n(0),i=n(1);e.exports=function(e,t){var n=(o.Object||{})[e]||Object[e],a={};a[e]=t(n),r(r.S+r.F*i(function(){n(1)}),"Object",a)}},function(e,t){e.exports=function(e,t){return{enumerable:!(1&e),configurable:!(2&e),writable:!(4&e),value:t}}},function(e,t,n){var r=n(42)("keys"),o=n(46);e.exports=function(e){return r[e]||(r[e]=o(e))}},function(e,t,n){var r=n(3),o=r["__core-js_shared__"]||(r["__core-js_shared__"]={});e.exports=function(e){return o[e]||(o[e]={})}},function(e,t,n){var r=n(9),o=Math.max,i=Math.min;e.exports=function(e,t){return e=r(e),e<0?o(e+t,0):i(e,t)}},function(e,t,n){var r=n(9),o=Math.min;e.exports=function(e){return e>0?o(r(e),9007199254740991):0}},function(e,t,n){var r=n(4);e.exports=function(e,t){if(!r(e))return e;var n,o;if(t&&"function"==typeof(n=e.toString)&&!r(o=n.call(e)))return o;if("function"==typeof(n=e.valueOf)&&!r(o=n.call(e)))return o;if(!t&&"function"==typeof(n=e.toString)&&!r(o=n.call(e)))return o;throw TypeError("Can't convert object to primitive value")}},function(e,t){var n=0,r=Math.random();e.exports=function(e){return"Symbol(".concat(void 0===e?"":e,")_",(++n+r).toString(36))}},function(e,t,n){var r=n(6);r(r.S+r.F,"Object",{assign:n(34)})},function(e,t,n){var r=n(11),o=n(8);n(39)("keys",function(){return function(e){return o(r(e))}})},function(e,t,n){t=e.exports=n(12)(void 0),t.push([e.i,".sc-checkbox-group{padding-top:9px}",""])},function(e,t,n){t=e.exports=n(12)(void 0),t.push([e.i,".sc-table .tool-bar{margin-bottom:20px}.sc-table .action-list{text-align:center}.sc-table .action-list>span{margin-right:10px}.sc-table .action-list>span:last-child{margin-right:0}.sc-table .el-tooltip,.sc-table .el-tooltip__rel{display:inline-block!important}.sc-table .pagination-wrap{text-align:center;margin-top:20px}",""])},function(e,t,n){var r,o,i;/*!
- * javascript-debounce 1.0.0
- *
- * A lightweight, dependency-free JavaScript module for debouncing functions based on David Walsh's debounce function.
- *
- * Source code available at: https://github.com/jgarber623/javascript-debounce
- *
- * (c) 2015-present Jason Garber (http://sixtwothree.org)
- *
- * javascript-debounce may be freely distributed under the MIT license.
- */
-!function(n,a){o=[],r=a,void 0!==(i="function"==typeof r?r.apply(t,o):r)&&(e.exports=i)}(0,function(){"use strict";return function(e,t){var n;return function(){var r=this,o=arguments;clearTimeout(n),n=setTimeout(function(){e.apply(r,o)},t)}}})},function(e,t,n){function r(e){n(55)}var o=n(13)(n(19),n(53),r,null,null);e.exports=o.exports},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,n=e._self._c||t;return n("div",{staticClass:"sc-checkbox-group"},[n("el-checkbox-group",{on:{change:e.changeHandler},model:{value:e.checkList,callback:function(t){e.checkList=t},expression:"checkList"}},e._l(e.checks,function(t){return n("el-checkbox",{key:t.code,attrs:{label:t.code}},[e._v(e._s(t.name))])}))],1)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,n=e._self._c||t;return n("div",{staticClass:"sc-table"},[e.showActionBar?n("el-row",{staticClass:"tool-bar"},[e.actionsShow?n("el-col",e._b({staticClass:"actions"},"el-col",e.innerActionsDef.colProps,!1),e._l(e.innerActionsDef.def,function(t){return n("el-button",e._b({key:t.name,attrs:{icon:t.icon,type:t.buttonProps&&t.buttonProps.type||"primary"},on:{click:t.handler}},"el-button",t.buttonProps,!1),[e._v(e._s(t.name))])})):e._e(),e.checkboxShow?n("el-col",e._b({staticClass:"filters"},"el-col",e.innerCheckboxFilterDef.colProps,!1),[n("checkbox-group",{attrs:{checks:e.innerCheckboxFilterDef.def},on:{checkChange:e.handleFilterChange}})],1):e._e(),e.searchShow?n("el-col",e._b({staticClass:"search",attrs:{span:e.innerSearchDef.colProps&&e.innerSearchDef.colProps.span||5}},"el-col",e.innerSearchDef.colProps,!1),[n("el-input",e._b({attrs:{icon:"search"},model:{value:e.searchKey,callback:function(t){e.searchKey=t},expression:"searchKey"}},"el-input",e.innerSearchDef.inputProps,!1))],1):e._e()],1):e._e(),n("div",{staticClass:"custom-tool-bar"},[e._t("custom-tool-bar")],2),n("el-table",e._b({ref:"elTable",staticStyle:{width:"100%"},attrs:{data:e.curTableData},on:{"sort-change":e.handleSort}},"el-table",e.innerTableProps,!1),[e._t("default"),e.actionColShow?n("el-table-column",{attrs:{prop:e.actionColProp,fixed:e.innerActionColDef.fixed,label:e.innerActionColDef.label,type:e.innerActionColDef.type,width:e.innerActionColDef.width,minWidth:e.innerActionColDef.minWidth},scopedSlots:e._u([{key:"default",fn:function(t){return[n("div",{staticClass:"action-list"},e._l(e.innerActionColDef.def,function(r){return n("span",[n("el-button",{attrs:{type:r.type||"text",icon:r.icon},on:{click:function(e){r.handler(t.row,t.$index,t.column,t.store)}}},[e._v(e._s(r.name))])],1)}))]}}])}):e._e()],2),e.paginationShow?n("div",{staticClass:"pagination-wrap"},[n("el-pagination",{attrs:{"current-page":e.currentPage,"page-sizes":e.innerPaginationDef.pageSizes,"page-size":e.innerPageSize,layout:e.innerPaginationDef.layout,total:e.total},on:{"size-change":e.handleSizeChange,"current-change":e.handleCurrentChange}})],1):e._e()],1)},staticRenderFns:[]}},function(e,t,n){var r=n(49);"string"==typeof r&&(r=[[e.i,r,""]]),r.locals&&(e.exports=r.locals);n(14)("668ac427",r,!0)},function(e,t,n){var r=n(50);"string"==typeof r&&(r=[[e.i,r,""]]),r.locals&&(e.exports=r.locals);n(14)("16e9a3a6",r,!0)},function(e,t){e.exports=function(e,t){for(var n=[],r={},o=0;o tag
+var util = _interopRequireWildcard(_util);
-// load the styles
-var content = __webpack_require__(83);
-if(typeof content === 'string') content = [[module.i, content, '']];
-// Prepare cssTransformation
-var transform;
+function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj["default"] = obj; return newObj; } }
-var options = {}
-options.transform = transform
-// add the styles to the DOM
-var update = __webpack_require__(86)(content, options);
-if(content.locals) module.exports = content.locals;
-// Hot Module Replacement
-if(false) {
- // When the styles change, update the