init
This commit is contained in:
35
public/static/libs/element-ui/lib/utils/after-leave.js
Normal file
35
public/static/libs/element-ui/lib/utils/after-leave.js
Normal file
@@ -0,0 +1,35 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
|
||||
exports.default = function (instance, callback) {
|
||||
var speed = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 300;
|
||||
var once = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
|
||||
|
||||
if (!instance || !callback) throw new Error('instance & callback is required');
|
||||
var called = false;
|
||||
var afterLeaveCallback = function afterLeaveCallback() {
|
||||
if (called) return;
|
||||
called = true;
|
||||
if (callback) {
|
||||
callback.apply(null, arguments);
|
||||
}
|
||||
};
|
||||
if (once) {
|
||||
instance.$once('after-leave', afterLeaveCallback);
|
||||
} else {
|
||||
instance.$on('after-leave', afterLeaveCallback);
|
||||
}
|
||||
setTimeout(function () {
|
||||
afterLeaveCallback();
|
||||
}, speed + 100);
|
||||
};
|
||||
|
||||
; /**
|
||||
* Bind after-leave event for vue instance. Make sure after-leave is called in any browsers.
|
||||
*
|
||||
* @param {Vue} instance Vue instance.
|
||||
* @param {Function} callback callback of after-leave event
|
||||
* @param {Number} speed the speed of transition, default value is 300ms
|
||||
* @param {Boolean} once weather bind after-leave once. default value is false.
|
||||
*/
|
||||
104
public/static/libs/element-ui/lib/utils/aria-dialog.js
Normal file
104
public/static/libs/element-ui/lib/utils/aria-dialog.js
Normal file
@@ -0,0 +1,104 @@
|
||||
'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 _ariaUtils = require('./aria-utils');
|
||||
|
||||
var _ariaUtils2 = _interopRequireDefault(_ariaUtils);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
/**
|
||||
* @constructor
|
||||
* @desc Dialog object providing modal focus management.
|
||||
*
|
||||
* Assumptions: The element serving as the dialog container is present in the
|
||||
* DOM and hidden. The dialog container has role='dialog'.
|
||||
*
|
||||
* @param dialogId
|
||||
* The ID of the element serving as the dialog container.
|
||||
* @param focusAfterClosed
|
||||
* Either the DOM node or the ID of the DOM node to focus when the
|
||||
* dialog closes.
|
||||
* @param focusFirst
|
||||
* Optional parameter containing either the DOM node or the ID of the
|
||||
* DOM node to focus when the dialog opens. If not specified, the
|
||||
* first focusable element in the dialog will receive focus.
|
||||
*/
|
||||
var aria = aria || {};
|
||||
var tabEvent;
|
||||
|
||||
aria.Dialog = function (dialog, focusAfterClosed, focusFirst) {
|
||||
var _this = this;
|
||||
|
||||
this.dialogNode = dialog;
|
||||
if (this.dialogNode === null || this.dialogNode.getAttribute('role') !== 'dialog') {
|
||||
throw new Error('Dialog() requires a DOM element with ARIA role of dialog.');
|
||||
}
|
||||
|
||||
if (typeof focusAfterClosed === 'string') {
|
||||
this.focusAfterClosed = document.getElementById(focusAfterClosed);
|
||||
} else if ((typeof focusAfterClosed === 'undefined' ? 'undefined' : _typeof(focusAfterClosed)) === 'object') {
|
||||
this.focusAfterClosed = focusAfterClosed;
|
||||
} else {
|
||||
this.focusAfterClosed = null;
|
||||
}
|
||||
|
||||
if (typeof focusFirst === 'string') {
|
||||
this.focusFirst = document.getElementById(focusFirst);
|
||||
} else if ((typeof focusFirst === 'undefined' ? 'undefined' : _typeof(focusFirst)) === 'object') {
|
||||
this.focusFirst = focusFirst;
|
||||
} else {
|
||||
this.focusFirst = null;
|
||||
}
|
||||
|
||||
if (this.focusFirst) {
|
||||
this.focusFirst.focus();
|
||||
} else {
|
||||
_ariaUtils2.default.focusFirstDescendant(this.dialogNode);
|
||||
}
|
||||
|
||||
this.lastFocus = document.activeElement;
|
||||
tabEvent = function tabEvent(e) {
|
||||
_this.trapFocus(e);
|
||||
};
|
||||
this.addListeners();
|
||||
};
|
||||
|
||||
aria.Dialog.prototype.addListeners = function () {
|
||||
document.addEventListener('focus', tabEvent, true);
|
||||
};
|
||||
|
||||
aria.Dialog.prototype.removeListeners = function () {
|
||||
document.removeEventListener('focus', tabEvent, true);
|
||||
};
|
||||
|
||||
aria.Dialog.prototype.closeDialog = function () {
|
||||
var _this2 = this;
|
||||
|
||||
this.removeListeners();
|
||||
if (this.focusAfterClosed) {
|
||||
setTimeout(function () {
|
||||
_this2.focusAfterClosed.focus();
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
aria.Dialog.prototype.trapFocus = function (event) {
|
||||
if (_ariaUtils2.default.IgnoreUtilFocusChanges) {
|
||||
return;
|
||||
}
|
||||
if (this.dialogNode.contains(event.target)) {
|
||||
this.lastFocus = event.target;
|
||||
} else {
|
||||
_ariaUtils2.default.focusFirstDescendant(this.dialogNode);
|
||||
if (this.lastFocus === document.activeElement) {
|
||||
_ariaUtils2.default.focusLastDescendant(this.dialogNode);
|
||||
}
|
||||
this.lastFocus = document.activeElement;
|
||||
}
|
||||
};
|
||||
|
||||
exports.default = aria.Dialog;
|
||||
126
public/static/libs/element-ui/lib/utils/aria-utils.js
Normal file
126
public/static/libs/element-ui/lib/utils/aria-utils.js
Normal file
@@ -0,0 +1,126 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
var aria = aria || {};
|
||||
|
||||
aria.Utils = aria.Utils || {};
|
||||
|
||||
/**
|
||||
* @desc Set focus on descendant nodes until the first focusable element is
|
||||
* found.
|
||||
* @param element
|
||||
* DOM node for which to find the first focusable descendant.
|
||||
* @returns
|
||||
* true if a focusable element is found and focus is set.
|
||||
*/
|
||||
aria.Utils.focusFirstDescendant = function (element) {
|
||||
for (var i = 0; i < element.childNodes.length; i++) {
|
||||
var child = element.childNodes[i];
|
||||
if (aria.Utils.attemptFocus(child) || aria.Utils.focusFirstDescendant(child)) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
};
|
||||
|
||||
/**
|
||||
* @desc Find the last descendant node that is focusable.
|
||||
* @param element
|
||||
* DOM node for which to find the last focusable descendant.
|
||||
* @returns
|
||||
* true if a focusable element is found and focus is set.
|
||||
*/
|
||||
|
||||
aria.Utils.focusLastDescendant = function (element) {
|
||||
for (var i = element.childNodes.length - 1; i >= 0; i--) {
|
||||
var child = element.childNodes[i];
|
||||
if (aria.Utils.attemptFocus(child) || aria.Utils.focusLastDescendant(child)) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
};
|
||||
|
||||
/**
|
||||
* @desc Set Attempt to set focus on the current node.
|
||||
* @param element
|
||||
* The node to attempt to focus on.
|
||||
* @returns
|
||||
* true if element is focused.
|
||||
*/
|
||||
aria.Utils.attemptFocus = function (element) {
|
||||
if (!aria.Utils.isFocusable(element)) {
|
||||
return false;
|
||||
}
|
||||
aria.Utils.IgnoreUtilFocusChanges = true;
|
||||
try {
|
||||
element.focus();
|
||||
} catch (e) {}
|
||||
aria.Utils.IgnoreUtilFocusChanges = false;
|
||||
return document.activeElement === element;
|
||||
};
|
||||
|
||||
aria.Utils.isFocusable = function (element) {
|
||||
if (element.tabIndex > 0 || element.tabIndex === 0 && element.getAttribute('tabIndex') !== null) {
|
||||
return true;
|
||||
}
|
||||
|
||||
if (element.disabled) {
|
||||
return false;
|
||||
}
|
||||
|
||||
switch (element.nodeName) {
|
||||
case 'A':
|
||||
return !!element.href && element.rel !== 'ignore';
|
||||
case 'INPUT':
|
||||
return element.type !== 'hidden' && element.type !== 'file';
|
||||
case 'BUTTON':
|
||||
case 'SELECT':
|
||||
case 'TEXTAREA':
|
||||
return true;
|
||||
default:
|
||||
return false;
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* 触发一个事件
|
||||
* mouseenter, mouseleave, mouseover, keyup, change, click 等
|
||||
* @param {Element} elm
|
||||
* @param {String} name
|
||||
* @param {*} opts
|
||||
*/
|
||||
aria.Utils.triggerEvent = function (elm, name) {
|
||||
var eventName = void 0;
|
||||
|
||||
if (/^mouse|click/.test(name)) {
|
||||
eventName = 'MouseEvents';
|
||||
} else if (/^key/.test(name)) {
|
||||
eventName = 'KeyboardEvent';
|
||||
} else {
|
||||
eventName = 'HTMLEvents';
|
||||
}
|
||||
var evt = document.createEvent(eventName);
|
||||
|
||||
for (var _len = arguments.length, opts = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {
|
||||
opts[_key - 2] = arguments[_key];
|
||||
}
|
||||
|
||||
evt.initEvent.apply(evt, [name].concat(opts));
|
||||
elm.dispatchEvent ? elm.dispatchEvent(evt) : elm.fireEvent('on' + name, evt);
|
||||
|
||||
return elm;
|
||||
};
|
||||
|
||||
aria.Utils.keys = {
|
||||
tab: 9,
|
||||
enter: 13,
|
||||
space: 32,
|
||||
left: 37,
|
||||
up: 38,
|
||||
right: 39,
|
||||
down: 40,
|
||||
esc: 27
|
||||
};
|
||||
|
||||
exports.default = aria.Utils;
|
||||
79
public/static/libs/element-ui/lib/utils/clickoutside.js
Normal file
79
public/static/libs/element-ui/lib/utils/clickoutside.js
Normal file
@@ -0,0 +1,79 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
|
||||
var _vue = require('vue');
|
||||
|
||||
var _vue2 = _interopRequireDefault(_vue);
|
||||
|
||||
var _dom = require('element-ui/lib/utils/dom');
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var nodeList = [];
|
||||
var ctx = '@@clickoutsideContext';
|
||||
|
||||
var startClick = void 0;
|
||||
var seed = 0;
|
||||
|
||||
!_vue2.default.prototype.$isServer && (0, _dom.on)(document, 'mousedown', function (e) {
|
||||
return startClick = e;
|
||||
});
|
||||
|
||||
!_vue2.default.prototype.$isServer && (0, _dom.on)(document, 'mouseup', function (e) {
|
||||
nodeList.forEach(function (node) {
|
||||
return node[ctx].documentHandler(e, startClick);
|
||||
});
|
||||
});
|
||||
|
||||
function createDocumentHandler(el, binding, vnode) {
|
||||
return function () {
|
||||
var mouseup = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
||||
var mousedown = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
||||
|
||||
if (!vnode || !vnode.context || !mouseup.target || !mousedown.target || el.contains(mouseup.target) || el.contains(mousedown.target) || el === mouseup.target || vnode.context.popperElm && (vnode.context.popperElm.contains(mouseup.target) || vnode.context.popperElm.contains(mousedown.target))) return;
|
||||
|
||||
if (binding.expression && el[ctx].methodName && vnode.context[el[ctx].methodName]) {
|
||||
vnode.context[el[ctx].methodName]();
|
||||
} else {
|
||||
el[ctx].bindingFn && el[ctx].bindingFn();
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
/**
|
||||
* v-clickoutside
|
||||
* @desc 点击元素外面才会触发的事件
|
||||
* @example
|
||||
* ```vue
|
||||
* <div v-element-clickoutside="handleClose">
|
||||
* ```
|
||||
*/
|
||||
exports.default = {
|
||||
bind: function bind(el, binding, vnode) {
|
||||
nodeList.push(el);
|
||||
var id = seed++;
|
||||
el[ctx] = {
|
||||
id: id,
|
||||
documentHandler: createDocumentHandler(el, binding, vnode),
|
||||
methodName: binding.expression,
|
||||
bindingFn: binding.value
|
||||
};
|
||||
},
|
||||
update: function update(el, binding, vnode) {
|
||||
el[ctx].documentHandler = createDocumentHandler(el, binding, vnode);
|
||||
el[ctx].methodName = binding.expression;
|
||||
el[ctx].bindingFn = binding.value;
|
||||
},
|
||||
unbind: function unbind(el) {
|
||||
var len = nodeList.length;
|
||||
|
||||
for (var i = 0; i < len; i++) {
|
||||
if (nodeList[i][ctx].id === el[ctx].id) {
|
||||
nodeList.splice(i, 1);
|
||||
break;
|
||||
}
|
||||
}
|
||||
delete el[ctx];
|
||||
}
|
||||
};
|
||||
310
public/static/libs/element-ui/lib/utils/date-util.js
Normal file
310
public/static/libs/element-ui/lib/utils/date-util.js
Normal file
@@ -0,0 +1,310 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
exports.validateRangeInOneMonth = exports.extractTimeFormat = exports.extractDateFormat = exports.nextYear = exports.prevYear = exports.nextMonth = exports.prevMonth = exports.changeYearMonthAndClampDate = exports.timeWithinRange = exports.limitTimeRange = exports.clearMilliseconds = exports.clearTime = exports.modifyWithTimeString = exports.modifyTime = exports.modifyDate = exports.range = exports.getRangeMinutes = exports.getMonthDays = exports.getPrevMonthLastDays = exports.getRangeHours = exports.getWeekNumber = exports.getStartDateOfMonth = exports.nextDate = exports.prevDate = exports.getFirstDayOfMonth = exports.getDayCountOfYear = exports.getDayCountOfMonth = exports.parseDate = exports.formatDate = exports.isDateObject = exports.isDate = exports.toDate = exports.getI18nSettings = undefined;
|
||||
|
||||
var _date = require('element-ui/lib/utils/date');
|
||||
|
||||
var _date2 = _interopRequireDefault(_date);
|
||||
|
||||
var _locale = require('element-ui/lib/locale');
|
||||
|
||||
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 newArray = function newArray(start, end) {
|
||||
var result = [];
|
||||
for (var i = start; i <= end; i++) {
|
||||
result.push(i);
|
||||
}
|
||||
return result;
|
||||
};
|
||||
|
||||
var getI18nSettings = exports.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 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;
|
||||
if (Array.isArray(date)) return false; // deal with `new Date([ new Date() ]) -> new Date()`
|
||||
return true;
|
||||
};
|
||||
|
||||
var isDateObject = exports.isDateObject = function isDateObject(val) {
|
||||
return val instanceof Date;
|
||||
};
|
||||
|
||||
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 (isNaN(+month)) return 31;
|
||||
|
||||
return new Date(year, +month + 1, 0).getDate();
|
||||
};
|
||||
|
||||
var getDayCountOfYear = exports.getDayCountOfYear = function getDayCountOfYear(year) {
|
||||
var isLeapYear = year % 400 === 0 || year % 100 !== 0 && year % 4 === 0;
|
||||
return isLeapYear ? 366 : 365;
|
||||
};
|
||||
|
||||
var getFirstDayOfMonth = exports.getFirstDayOfMonth = function getFirstDayOfMonth(date) {
|
||||
var temp = new Date(date.getTime());
|
||||
temp.setDate(1);
|
||||
return temp.getDay();
|
||||
};
|
||||
|
||||
// see: https://stackoverflow.com/questions/3674539/incrementing-a-date-in-javascript
|
||||
// {prev, next} Date should work for Daylight Saving Time
|
||||
// Adding 24 * 60 * 60 * 1000 does not work in the above scenario
|
||||
var prevDate = exports.prevDate = function prevDate(date) {
|
||||
var amount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
|
||||
|
||||
return new Date(date.getFullYear(), date.getMonth(), date.getDate() - amount);
|
||||
};
|
||||
|
||||
var nextDate = exports.nextDate = function nextDate(date) {
|
||||
var amount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
|
||||
|
||||
return new Date(date.getFullYear(), date.getMonth(), date.getDate() + amount);
|
||||
};
|
||||
|
||||
var getStartDateOfMonth = exports.getStartDateOfMonth = function getStartDateOfMonth(year, month) {
|
||||
var result = new Date(year, month, 1);
|
||||
var day = result.getDay();
|
||||
|
||||
if (day === 0) {
|
||||
return prevDate(result, 7);
|
||||
} else {
|
||||
return prevDate(result, day);
|
||||
}
|
||||
};
|
||||
|
||||
var getWeekNumber = exports.getWeekNumber = function getWeekNumber(src) {
|
||||
if (!isDate(src)) return null;
|
||||
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.
|
||||
// Rounding should be fine for Daylight Saving Time. Its shift should never be more than 12 hours.
|
||||
return 1 + Math.round(((date.getTime() - week1.getTime()) / 86400000 - 3 + (week1.getDay() + 6) % 7) / 7);
|
||||
};
|
||||
|
||||
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 getPrevMonthLastDays = exports.getPrevMonthLastDays = function getPrevMonthLastDays(date, amount) {
|
||||
if (amount <= 0) return [];
|
||||
var temp = new Date(date.getTime());
|
||||
temp.setDate(0);
|
||||
var lastDay = temp.getDate();
|
||||
return range(amount).map(function (_, index) {
|
||||
return lastDay - (amount - index - 1);
|
||||
});
|
||||
};
|
||||
|
||||
var getMonthDays = exports.getMonthDays = function getMonthDays(date) {
|
||||
var temp = new Date(date.getFullYear(), date.getMonth() + 1, 0);
|
||||
var days = temp.getDate();
|
||||
return range(days).map(function (_, index) {
|
||||
return index + 1;
|
||||
});
|
||||
};
|
||||
|
||||
function setRangeData(arr, start, end, value) {
|
||||
for (var i = start; i < end; i++) {
|
||||
arr[i] = value;
|
||||
}
|
||||
}
|
||||
|
||||
var getRangeMinutes = exports.getRangeMinutes = function getRangeMinutes(ranges, hour) {
|
||||
var minutes = new Array(60);
|
||||
|
||||
if (ranges.length > 0) {
|
||||
ranges.forEach(function (range) {
|
||||
var start = range[0];
|
||||
var end = range[1];
|
||||
var startHour = start.getHours();
|
||||
var startMinute = start.getMinutes();
|
||||
var endHour = end.getHours();
|
||||
var endMinute = end.getMinutes();
|
||||
if (startHour === hour && endHour !== hour) {
|
||||
setRangeData(minutes, startMinute, 60, true);
|
||||
} else if (startHour === hour && endHour === hour) {
|
||||
setRangeData(minutes, startMinute, endMinute + 1, true);
|
||||
} else if (startHour !== hour && endHour === hour) {
|
||||
setRangeData(minutes, 0, endMinute + 1, true);
|
||||
} else if (startHour < hour && endHour > hour) {
|
||||
setRangeData(minutes, 0, 60, true);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
setRangeData(minutes, 0, 60, true);
|
||||
}
|
||||
return minutes;
|
||||
};
|
||||
|
||||
var range = exports.range = function range(n) {
|
||||
// see https://stackoverflow.com/questions/3746725/create-a-javascript-array-containing-1-n
|
||||
return Array.apply(null, { length: n }).map(function (_, n) {
|
||||
return n;
|
||||
});
|
||||
};
|
||||
|
||||
var modifyDate = exports.modifyDate = function modifyDate(date, y, m, d) {
|
||||
return new Date(y, m, d, date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds());
|
||||
};
|
||||
|
||||
var modifyTime = exports.modifyTime = function modifyTime(date, h, m, s) {
|
||||
return new Date(date.getFullYear(), date.getMonth(), date.getDate(), h, m, s, date.getMilliseconds());
|
||||
};
|
||||
|
||||
var modifyWithTimeString = exports.modifyWithTimeString = function modifyWithTimeString(date, time) {
|
||||
if (date == null || !time) {
|
||||
return date;
|
||||
}
|
||||
time = parseDate(time, 'HH:mm:ss');
|
||||
return modifyTime(date, time.getHours(), time.getMinutes(), time.getSeconds());
|
||||
};
|
||||
|
||||
var clearTime = exports.clearTime = function clearTime(date) {
|
||||
return new Date(date.getFullYear(), date.getMonth(), date.getDate());
|
||||
};
|
||||
|
||||
var clearMilliseconds = exports.clearMilliseconds = function clearMilliseconds(date) {
|
||||
return new Date(date.getFullYear(), date.getMonth(), date.getDate(), date.getHours(), date.getMinutes(), date.getSeconds(), 0);
|
||||
};
|
||||
|
||||
var limitTimeRange = exports.limitTimeRange = function limitTimeRange(date, ranges) {
|
||||
var format = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'HH:mm:ss';
|
||||
|
||||
// TODO: refactory a more elegant solution
|
||||
if (ranges.length === 0) return date;
|
||||
var normalizeDate = function normalizeDate(date) {
|
||||
return _date2.default.parse(_date2.default.format(date, format), format);
|
||||
};
|
||||
var ndate = normalizeDate(date);
|
||||
var nranges = ranges.map(function (range) {
|
||||
return range.map(normalizeDate);
|
||||
});
|
||||
if (nranges.some(function (nrange) {
|
||||
return ndate >= nrange[0] && ndate <= nrange[1];
|
||||
})) return date;
|
||||
|
||||
var minDate = nranges[0][0];
|
||||
var maxDate = nranges[0][0];
|
||||
|
||||
nranges.forEach(function (nrange) {
|
||||
minDate = new Date(Math.min(nrange[0], minDate));
|
||||
maxDate = new Date(Math.max(nrange[1], minDate));
|
||||
});
|
||||
|
||||
var ret = ndate < minDate ? minDate : maxDate;
|
||||
// preserve Year/Month/Date
|
||||
return modifyDate(ret, date.getFullYear(), date.getMonth(), date.getDate());
|
||||
};
|
||||
|
||||
var timeWithinRange = exports.timeWithinRange = function timeWithinRange(date, selectableRange, format) {
|
||||
var limitedDate = limitTimeRange(date, selectableRange, format);
|
||||
return limitedDate.getTime() === date.getTime();
|
||||
};
|
||||
|
||||
var changeYearMonthAndClampDate = exports.changeYearMonthAndClampDate = function changeYearMonthAndClampDate(date, year, month) {
|
||||
// clamp date to the number of days in `year`, `month`
|
||||
// eg: (2010-1-31, 2010, 2) => 2010-2-28
|
||||
var monthDate = Math.min(date.getDate(), getDayCountOfMonth(year, month));
|
||||
return modifyDate(date, year, month, monthDate);
|
||||
};
|
||||
|
||||
var prevMonth = exports.prevMonth = function prevMonth(date) {
|
||||
var year = date.getFullYear();
|
||||
var month = date.getMonth();
|
||||
return month === 0 ? changeYearMonthAndClampDate(date, year - 1, 11) : changeYearMonthAndClampDate(date, year, month - 1);
|
||||
};
|
||||
|
||||
var nextMonth = exports.nextMonth = function nextMonth(date) {
|
||||
var year = date.getFullYear();
|
||||
var month = date.getMonth();
|
||||
return month === 11 ? changeYearMonthAndClampDate(date, year + 1, 0) : changeYearMonthAndClampDate(date, year, month + 1);
|
||||
};
|
||||
|
||||
var prevYear = exports.prevYear = function prevYear(date) {
|
||||
var amount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
|
||||
|
||||
var year = date.getFullYear();
|
||||
var month = date.getMonth();
|
||||
return changeYearMonthAndClampDate(date, year - amount, month);
|
||||
};
|
||||
|
||||
var nextYear = exports.nextYear = function nextYear(date) {
|
||||
var amount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
|
||||
|
||||
var year = date.getFullYear();
|
||||
var month = date.getMonth();
|
||||
return changeYearMonthAndClampDate(date, year + amount, month);
|
||||
};
|
||||
|
||||
var extractDateFormat = exports.extractDateFormat = function extractDateFormat(format) {
|
||||
return format.replace(/\W?m{1,2}|\W?ZZ/g, '').replace(/\W?h{1,2}|\W?s{1,3}|\W?a/gi, '').trim();
|
||||
};
|
||||
|
||||
var extractTimeFormat = exports.extractTimeFormat = function extractTimeFormat(format) {
|
||||
return format.replace(/\W?D{1,2}|\W?Do|\W?d{1,4}|\W?M{1,4}|\W?y{2,4}/g, '').trim();
|
||||
};
|
||||
|
||||
var validateRangeInOneMonth = exports.validateRangeInOneMonth = function validateRangeInOneMonth(start, end) {
|
||||
return start.getMonth() === end.getMonth() && start.getFullYear() === end.getFullYear();
|
||||
};
|
||||
369
public/static/libs/element-ui/lib/utils/date.js
Normal file
369
public/static/libs/element-ui/lib/utils/date.js
Normal file
@@ -0,0 +1,369 @@
|
||||
'use strict';
|
||||
|
||||
/* 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 = '[^\\s]+';
|
||||
var literal = /\[([^]*?)\]/gm;
|
||||
var noop = function noop() {};
|
||||
|
||||
function regexEscape(str) {
|
||||
return str.replace(/[|\\{()[^$+*?.-]/g, '\\$&');
|
||||
}
|
||||
|
||||
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 pad(String(dateObj.getFullYear()), 4).substr(2);
|
||||
},
|
||||
yyyy: function yyyy(dateObj) {
|
||||
return pad(dateObj.getFullYear(), 4);
|
||||
},
|
||||
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;
|
||||
}],
|
||||
Do: [twoDigits + word, function (d, v) {
|
||||
d.day = parseInt(v, 10);
|
||||
}],
|
||||
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: ['[^\\s]*?[\\+\\-]\\d\\d:?\\d\\d|[^\\s]*?Z', 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.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');
|
||||
}
|
||||
|
||||
mask = fecha.masks[mask] || mask || fecha.masks['default'];
|
||||
|
||||
var literals = [];
|
||||
|
||||
// Make literals inactive by replacing them with ??
|
||||
mask = mask.replace(literal, function ($0, $1) {
|
||||
literals.push($1);
|
||||
return '@@@';
|
||||
});
|
||||
// Apply formatting rules
|
||||
mask = mask.replace(token, function ($0) {
|
||||
return $0 in formatFlags ? formatFlags[$0](dateObj, i18n) : $0.slice(1, $0.length - 1);
|
||||
});
|
||||
// Inline literal values back into the formatted value
|
||||
return mask.replace(/@@@/g, function () {
|
||||
return literals.shift();
|
||||
});
|
||||
};
|
||||
|
||||
/**
|
||||
* 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;
|
||||
|
||||
// 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 null;
|
||||
}
|
||||
|
||||
var dateInfo = {};
|
||||
var parseInfo = [];
|
||||
var literals = [];
|
||||
format = format.replace(literal, function ($0, $1) {
|
||||
literals.push($1);
|
||||
return '@@@';
|
||||
});
|
||||
var newFormat = regexEscape(format).replace(token, function ($0) {
|
||||
if (parseFlags[$0]) {
|
||||
var info = parseFlags[$0];
|
||||
parseInfo.push(info[1]);
|
||||
return '(' + info[0] + ')';
|
||||
}
|
||||
|
||||
return $0;
|
||||
});
|
||||
newFormat = newFormat.replace(/@@@/g, function () {
|
||||
return literals.shift();
|
||||
});
|
||||
var matches = dateStr.match(new RegExp(newFormat, 'i'));
|
||||
if (!matches) {
|
||||
return null;
|
||||
}
|
||||
|
||||
for (var i = 1; i < matches.length; i++) {
|
||||
parseInfo[i - 1](dateInfo, matches[i], i18n);
|
||||
}
|
||||
|
||||
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 (typeof define === 'function' && define.amd) {
|
||||
define(function () {
|
||||
return fecha;
|
||||
});
|
||||
} else {
|
||||
main.fecha = fecha;
|
||||
}
|
||||
})(undefined);
|
||||
234
public/static/libs/element-ui/lib/utils/dom.js
Normal file
234
public/static/libs/element-ui/lib/utils/dom.js
Normal file
@@ -0,0 +1,234 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
exports.isInContainer = exports.getScrollContainer = exports.isScroll = exports.getStyle = exports.once = exports.off = exports.on = 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; }; /* istanbul ignore next */
|
||||
|
||||
exports.hasClass = hasClass;
|
||||
exports.addClass = addClass;
|
||||
exports.removeClass = removeClass;
|
||||
exports.setStyle = setStyle;
|
||||
|
||||
var _vue = require('vue');
|
||||
|
||||
var _vue2 = _interopRequireDefault(_vue);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var isServer = _vue2.default.prototype.$isServer;
|
||||
var SPECIAL_CHARS_REGEXP = /([\:\-\_]+(.))/g;
|
||||
var MOZ_HACK_REGEXP = /^moz([A-Z])/;
|
||||
var ieVersion = isServer ? 0 : Number(document.documentMode);
|
||||
|
||||
/* istanbul ignore next */
|
||||
var trim = function trim(string) {
|
||||
return (string || '').replace(/^[\s\uFEFF]+|[\s\uFEFF]+$/g, '');
|
||||
};
|
||||
/* istanbul ignore next */
|
||||
var camelCase = function camelCase(name) {
|
||||
return name.replace(SPECIAL_CHARS_REGEXP, function (_, separator, letter, offset) {
|
||||
return offset ? letter.toUpperCase() : letter;
|
||||
}).replace(MOZ_HACK_REGEXP, 'Moz$1');
|
||||
};
|
||||
|
||||
/* istanbul ignore next */
|
||||
var on = exports.on = function () {
|
||||
if (!isServer && document.addEventListener) {
|
||||
return function (element, event, handler) {
|
||||
if (element && event && handler) {
|
||||
element.addEventListener(event, handler, false);
|
||||
}
|
||||
};
|
||||
} else {
|
||||
return function (element, event, handler) {
|
||||
if (element && event && handler) {
|
||||
element.attachEvent('on' + event, handler);
|
||||
}
|
||||
};
|
||||
}
|
||||
}();
|
||||
|
||||
/* istanbul ignore next */
|
||||
var off = exports.off = function () {
|
||||
if (!isServer && document.removeEventListener) {
|
||||
return function (element, event, handler) {
|
||||
if (element && event) {
|
||||
element.removeEventListener(event, handler, false);
|
||||
}
|
||||
};
|
||||
} else {
|
||||
return function (element, event, handler) {
|
||||
if (element && event) {
|
||||
element.detachEvent('on' + event, handler);
|
||||
}
|
||||
};
|
||||
}
|
||||
}();
|
||||
|
||||
/* istanbul ignore next */
|
||||
var once = exports.once = function once(el, event, fn) {
|
||||
var listener = function listener() {
|
||||
if (fn) {
|
||||
fn.apply(this, arguments);
|
||||
}
|
||||
off(el, event, listener);
|
||||
};
|
||||
on(el, event, listener);
|
||||
};
|
||||
|
||||
/* istanbul ignore next */
|
||||
function hasClass(el, cls) {
|
||||
if (!el || !cls) return false;
|
||||
if (cls.indexOf(' ') !== -1) throw new Error('className should not contain space.');
|
||||
if (el.classList) {
|
||||
return el.classList.contains(cls);
|
||||
} else {
|
||||
return (' ' + el.className + ' ').indexOf(' ' + cls + ' ') > -1;
|
||||
}
|
||||
};
|
||||
|
||||
/* istanbul ignore next */
|
||||
function addClass(el, cls) {
|
||||
if (!el) return;
|
||||
var curClass = el.className;
|
||||
var classes = (cls || '').split(' ');
|
||||
|
||||
for (var i = 0, j = classes.length; i < j; i++) {
|
||||
var clsName = classes[i];
|
||||
if (!clsName) continue;
|
||||
|
||||
if (el.classList) {
|
||||
el.classList.add(clsName);
|
||||
} else if (!hasClass(el, clsName)) {
|
||||
curClass += ' ' + clsName;
|
||||
}
|
||||
}
|
||||
if (!el.classList) {
|
||||
el.setAttribute('class', curClass);
|
||||
}
|
||||
};
|
||||
|
||||
/* istanbul ignore next */
|
||||
function removeClass(el, cls) {
|
||||
if (!el || !cls) return;
|
||||
var classes = cls.split(' ');
|
||||
var curClass = ' ' + el.className + ' ';
|
||||
|
||||
for (var i = 0, j = classes.length; i < j; i++) {
|
||||
var clsName = classes[i];
|
||||
if (!clsName) continue;
|
||||
|
||||
if (el.classList) {
|
||||
el.classList.remove(clsName);
|
||||
} else if (hasClass(el, clsName)) {
|
||||
curClass = curClass.replace(' ' + clsName + ' ', ' ');
|
||||
}
|
||||
}
|
||||
if (!el.classList) {
|
||||
el.setAttribute('class', trim(curClass));
|
||||
}
|
||||
};
|
||||
|
||||
/* istanbul ignore next */
|
||||
var getStyle = exports.getStyle = ieVersion < 9 ? function (element, styleName) {
|
||||
if (isServer) return;
|
||||
if (!element || !styleName) return null;
|
||||
styleName = camelCase(styleName);
|
||||
if (styleName === 'float') {
|
||||
styleName = 'styleFloat';
|
||||
}
|
||||
try {
|
||||
switch (styleName) {
|
||||
case 'opacity':
|
||||
try {
|
||||
return element.filters.item('alpha').opacity / 100;
|
||||
} catch (e) {
|
||||
return 1.0;
|
||||
}
|
||||
default:
|
||||
return element.style[styleName] || element.currentStyle ? element.currentStyle[styleName] : null;
|
||||
}
|
||||
} catch (e) {
|
||||
return element.style[styleName];
|
||||
}
|
||||
} : function (element, styleName) {
|
||||
if (isServer) return;
|
||||
if (!element || !styleName) return null;
|
||||
styleName = camelCase(styleName);
|
||||
if (styleName === 'float') {
|
||||
styleName = 'cssFloat';
|
||||
}
|
||||
try {
|
||||
var computed = document.defaultView.getComputedStyle(element, '');
|
||||
return element.style[styleName] || computed ? computed[styleName] : null;
|
||||
} catch (e) {
|
||||
return element.style[styleName];
|
||||
}
|
||||
};
|
||||
|
||||
/* istanbul ignore next */
|
||||
function setStyle(element, styleName, value) {
|
||||
if (!element || !styleName) return;
|
||||
|
||||
if ((typeof styleName === 'undefined' ? 'undefined' : _typeof(styleName)) === 'object') {
|
||||
for (var prop in styleName) {
|
||||
if (styleName.hasOwnProperty(prop)) {
|
||||
setStyle(element, prop, styleName[prop]);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
styleName = camelCase(styleName);
|
||||
if (styleName === 'opacity' && ieVersion < 9) {
|
||||
element.style.filter = isNaN(value) ? '' : 'alpha(opacity=' + value * 100 + ')';
|
||||
} else {
|
||||
element.style[styleName] = value;
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
var isScroll = exports.isScroll = function isScroll(el, vertical) {
|
||||
if (isServer) return;
|
||||
|
||||
var determinedDirection = vertical !== null && vertical !== undefined;
|
||||
var overflow = determinedDirection ? vertical ? getStyle(el, 'overflow-y') : getStyle(el, 'overflow-x') : getStyle(el, 'overflow');
|
||||
|
||||
return overflow.match(/(scroll|auto|overlay)/);
|
||||
};
|
||||
|
||||
var getScrollContainer = exports.getScrollContainer = function getScrollContainer(el, vertical) {
|
||||
if (isServer) return;
|
||||
|
||||
var parent = el;
|
||||
while (parent) {
|
||||
if ([window, document, document.documentElement].includes(parent)) {
|
||||
return window;
|
||||
}
|
||||
if (isScroll(parent, vertical)) {
|
||||
return parent;
|
||||
}
|
||||
parent = parent.parentNode;
|
||||
}
|
||||
|
||||
return parent;
|
||||
};
|
||||
|
||||
var isInContainer = exports.isInContainer = function isInContainer(el, container) {
|
||||
if (isServer || !el || !container) return false;
|
||||
|
||||
var elRect = el.getBoundingClientRect();
|
||||
var containerRect = void 0;
|
||||
|
||||
if ([window, document, document.documentElement, null, undefined].includes(container)) {
|
||||
containerRect = {
|
||||
top: 0,
|
||||
right: window.innerWidth,
|
||||
bottom: window.innerHeight,
|
||||
left: 0
|
||||
};
|
||||
} else {
|
||||
containerRect = container.getBoundingClientRect();
|
||||
}
|
||||
|
||||
return elRect.top < containerRect.bottom && elRect.bottom > containerRect.top && elRect.right > containerRect.left && elRect.left < containerRect.right;
|
||||
};
|
||||
9421
public/static/libs/element-ui/lib/utils/lodash.js
Normal file
9421
public/static/libs/element-ui/lib/utils/lodash.js
Normal file
File diff suppressed because it is too large
Load Diff
24
public/static/libs/element-ui/lib/utils/menu/aria-menubar.js
Normal file
24
public/static/libs/element-ui/lib/utils/menu/aria-menubar.js
Normal file
@@ -0,0 +1,24 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
|
||||
var _ariaMenuitem = require('./aria-menuitem');
|
||||
|
||||
var _ariaMenuitem2 = _interopRequireDefault(_ariaMenuitem);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var Menu = function Menu(domNode) {
|
||||
this.domNode = domNode;
|
||||
this.init();
|
||||
};
|
||||
|
||||
Menu.prototype.init = function () {
|
||||
var menuChildren = this.domNode.childNodes;
|
||||
[].filter.call(menuChildren, function (child) {
|
||||
return child.nodeType === 1;
|
||||
}).forEach(function (child) {
|
||||
new _ariaMenuitem2.default(child); // eslint-disable-line
|
||||
});
|
||||
};
|
||||
exports.default = Menu;
|
||||
@@ -0,0 +1,62 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
|
||||
var _ariaUtils = require('../aria-utils');
|
||||
|
||||
var _ariaUtils2 = _interopRequireDefault(_ariaUtils);
|
||||
|
||||
var _ariaSubmenu = require('./aria-submenu');
|
||||
|
||||
var _ariaSubmenu2 = _interopRequireDefault(_ariaSubmenu);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var MenuItem = function MenuItem(domNode) {
|
||||
this.domNode = domNode;
|
||||
this.submenu = null;
|
||||
this.init();
|
||||
};
|
||||
|
||||
MenuItem.prototype.init = function () {
|
||||
this.domNode.setAttribute('tabindex', '0');
|
||||
var menuChild = this.domNode.querySelector('.el-menu');
|
||||
if (menuChild) {
|
||||
this.submenu = new _ariaSubmenu2.default(this, menuChild);
|
||||
}
|
||||
this.addListeners();
|
||||
};
|
||||
|
||||
MenuItem.prototype.addListeners = function () {
|
||||
var _this = this;
|
||||
|
||||
var keys = _ariaUtils2.default.keys;
|
||||
this.domNode.addEventListener('keydown', function (event) {
|
||||
var prevDef = false;
|
||||
switch (event.keyCode) {
|
||||
case keys.down:
|
||||
_ariaUtils2.default.triggerEvent(event.currentTarget, 'mouseenter');
|
||||
_this.submenu && _this.submenu.gotoSubIndex(0);
|
||||
prevDef = true;
|
||||
break;
|
||||
case keys.up:
|
||||
_ariaUtils2.default.triggerEvent(event.currentTarget, 'mouseenter');
|
||||
_this.submenu && _this.submenu.gotoSubIndex(_this.submenu.subMenuItems.length - 1);
|
||||
prevDef = true;
|
||||
break;
|
||||
case keys.tab:
|
||||
_ariaUtils2.default.triggerEvent(event.currentTarget, 'mouseleave');
|
||||
break;
|
||||
case keys.enter:
|
||||
case keys.space:
|
||||
prevDef = true;
|
||||
event.currentTarget.click();
|
||||
break;
|
||||
}
|
||||
if (prevDef) {
|
||||
event.preventDefault();
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
exports.default = MenuItem;
|
||||
69
public/static/libs/element-ui/lib/utils/menu/aria-submenu.js
Normal file
69
public/static/libs/element-ui/lib/utils/menu/aria-submenu.js
Normal file
@@ -0,0 +1,69 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
|
||||
var _ariaUtils = require('../aria-utils');
|
||||
|
||||
var _ariaUtils2 = _interopRequireDefault(_ariaUtils);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var SubMenu = function SubMenu(parent, domNode) {
|
||||
this.domNode = domNode;
|
||||
this.parent = parent;
|
||||
this.subMenuItems = [];
|
||||
this.subIndex = 0;
|
||||
this.init();
|
||||
};
|
||||
|
||||
SubMenu.prototype.init = function () {
|
||||
this.subMenuItems = this.domNode.querySelectorAll('li');
|
||||
this.addListeners();
|
||||
};
|
||||
|
||||
SubMenu.prototype.gotoSubIndex = function (idx) {
|
||||
if (idx === this.subMenuItems.length) {
|
||||
idx = 0;
|
||||
} else if (idx < 0) {
|
||||
idx = this.subMenuItems.length - 1;
|
||||
}
|
||||
this.subMenuItems[idx].focus();
|
||||
this.subIndex = idx;
|
||||
};
|
||||
|
||||
SubMenu.prototype.addListeners = function () {
|
||||
var _this = this;
|
||||
|
||||
var keys = _ariaUtils2.default.keys;
|
||||
var parentNode = this.parent.domNode;
|
||||
Array.prototype.forEach.call(this.subMenuItems, function (el) {
|
||||
el.addEventListener('keydown', function (event) {
|
||||
var prevDef = false;
|
||||
switch (event.keyCode) {
|
||||
case keys.down:
|
||||
_this.gotoSubIndex(_this.subIndex + 1);
|
||||
prevDef = true;
|
||||
break;
|
||||
case keys.up:
|
||||
_this.gotoSubIndex(_this.subIndex - 1);
|
||||
prevDef = true;
|
||||
break;
|
||||
case keys.tab:
|
||||
_ariaUtils2.default.triggerEvent(parentNode, 'mouseleave');
|
||||
break;
|
||||
case keys.enter:
|
||||
case keys.space:
|
||||
prevDef = true;
|
||||
event.currentTarget.click();
|
||||
break;
|
||||
}
|
||||
if (prevDef) {
|
||||
event.preventDefault();
|
||||
event.stopPropagation();
|
||||
}
|
||||
return false;
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
exports.default = SubMenu;
|
||||
21
public/static/libs/element-ui/lib/utils/merge.js
Normal file
21
public/static/libs/element-ui/lib/utils/merge.js
Normal file
@@ -0,0 +1,21 @@
|
||||
"use strict";
|
||||
|
||||
exports.__esModule = true;
|
||||
|
||||
exports.default = function (target) {
|
||||
for (var i = 1, j = arguments.length; i < j; i++) {
|
||||
var source = arguments[i] || {};
|
||||
for (var prop in source) {
|
||||
if (source.hasOwnProperty(prop)) {
|
||||
var value = source[prop];
|
||||
if (value !== undefined) {
|
||||
target[prop] = value;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return target;
|
||||
};
|
||||
|
||||
;
|
||||
1261
public/static/libs/element-ui/lib/utils/popper.js
Normal file
1261
public/static/libs/element-ui/lib/utils/popper.js
Normal file
File diff suppressed because it is too large
Load Diff
233
public/static/libs/element-ui/lib/utils/popup/index.js
Normal file
233
public/static/libs/element-ui/lib/utils/popup/index.js
Normal file
@@ -0,0 +1,233 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
exports.PopupManager = undefined;
|
||||
|
||||
var _vue = require('vue');
|
||||
|
||||
var _vue2 = _interopRequireDefault(_vue);
|
||||
|
||||
var _merge = require('element-ui/lib/utils/merge');
|
||||
|
||||
var _merge2 = _interopRequireDefault(_merge);
|
||||
|
||||
var _popupManager = require('element-ui/lib/utils/popup/popup-manager');
|
||||
|
||||
var _popupManager2 = _interopRequireDefault(_popupManager);
|
||||
|
||||
var _scrollbarWidth = require('../scrollbar-width');
|
||||
|
||||
var _scrollbarWidth2 = _interopRequireDefault(_scrollbarWidth);
|
||||
|
||||
var _dom = require('../dom');
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var idSeed = 1;
|
||||
|
||||
var scrollBarWidth = void 0;
|
||||
|
||||
exports.default = {
|
||||
props: {
|
||||
visible: {
|
||||
type: Boolean,
|
||||
default: false
|
||||
},
|
||||
openDelay: {},
|
||||
closeDelay: {},
|
||||
zIndex: {},
|
||||
modal: {
|
||||
type: Boolean,
|
||||
default: false
|
||||
},
|
||||
modalFade: {
|
||||
type: Boolean,
|
||||
default: true
|
||||
},
|
||||
modalClass: {},
|
||||
modalAppendToBody: {
|
||||
type: Boolean,
|
||||
default: false
|
||||
},
|
||||
lockScroll: {
|
||||
type: Boolean,
|
||||
default: true
|
||||
},
|
||||
closeOnPressEscape: {
|
||||
type: Boolean,
|
||||
default: false
|
||||
},
|
||||
closeOnClickModal: {
|
||||
type: Boolean,
|
||||
default: false
|
||||
}
|
||||
},
|
||||
|
||||
beforeMount: function beforeMount() {
|
||||
this._popupId = 'popup-' + idSeed++;
|
||||
_popupManager2.default.register(this._popupId, this);
|
||||
},
|
||||
beforeDestroy: function beforeDestroy() {
|
||||
_popupManager2.default.deregister(this._popupId);
|
||||
_popupManager2.default.closeModal(this._popupId);
|
||||
|
||||
this.restoreBodyStyle();
|
||||
},
|
||||
data: function data() {
|
||||
return {
|
||||
opened: false,
|
||||
bodyPaddingRight: null,
|
||||
computedBodyPaddingRight: 0,
|
||||
withoutHiddenClass: true,
|
||||
rendered: false
|
||||
};
|
||||
},
|
||||
|
||||
|
||||
watch: {
|
||||
visible: function visible(val) {
|
||||
var _this = this;
|
||||
|
||||
if (val) {
|
||||
if (this._opening) return;
|
||||
if (!this.rendered) {
|
||||
this.rendered = true;
|
||||
_vue2.default.nextTick(function () {
|
||||
_this.open();
|
||||
});
|
||||
} else {
|
||||
this.open();
|
||||
}
|
||||
} else {
|
||||
this.close();
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
methods: {
|
||||
open: function open(options) {
|
||||
var _this2 = this;
|
||||
|
||||
if (!this.rendered) {
|
||||
this.rendered = true;
|
||||
}
|
||||
|
||||
var props = (0, _merge2.default)({}, this.$props || this, options);
|
||||
|
||||
if (this._closeTimer) {
|
||||
clearTimeout(this._closeTimer);
|
||||
this._closeTimer = null;
|
||||
}
|
||||
clearTimeout(this._openTimer);
|
||||
|
||||
var openDelay = Number(props.openDelay);
|
||||
if (openDelay > 0) {
|
||||
this._openTimer = setTimeout(function () {
|
||||
_this2._openTimer = null;
|
||||
_this2.doOpen(props);
|
||||
}, openDelay);
|
||||
} else {
|
||||
this.doOpen(props);
|
||||
}
|
||||
},
|
||||
doOpen: function doOpen(props) {
|
||||
if (this.$isServer) return;
|
||||
if (this.willOpen && !this.willOpen()) return;
|
||||
if (this.opened) return;
|
||||
|
||||
this._opening = true;
|
||||
|
||||
var dom = this.$el;
|
||||
|
||||
var modal = props.modal;
|
||||
|
||||
var zIndex = props.zIndex;
|
||||
if (zIndex) {
|
||||
_popupManager2.default.zIndex = zIndex;
|
||||
}
|
||||
|
||||
if (modal) {
|
||||
if (this._closing) {
|
||||
_popupManager2.default.closeModal(this._popupId);
|
||||
this._closing = false;
|
||||
}
|
||||
_popupManager2.default.openModal(this._popupId, _popupManager2.default.nextZIndex(), this.modalAppendToBody ? undefined : dom, props.modalClass, props.modalFade);
|
||||
if (props.lockScroll) {
|
||||
this.withoutHiddenClass = !(0, _dom.hasClass)(document.body, 'el-popup-parent--hidden');
|
||||
if (this.withoutHiddenClass) {
|
||||
this.bodyPaddingRight = document.body.style.paddingRight;
|
||||
this.computedBodyPaddingRight = parseInt((0, _dom.getStyle)(document.body, 'paddingRight'), 10);
|
||||
}
|
||||
scrollBarWidth = (0, _scrollbarWidth2.default)();
|
||||
var bodyHasOverflow = document.documentElement.clientHeight < document.body.scrollHeight;
|
||||
var bodyOverflowY = (0, _dom.getStyle)(document.body, 'overflowY');
|
||||
if (scrollBarWidth > 0 && (bodyHasOverflow || bodyOverflowY === 'scroll') && this.withoutHiddenClass) {
|
||||
document.body.style.paddingRight = this.computedBodyPaddingRight + scrollBarWidth + 'px';
|
||||
}
|
||||
(0, _dom.addClass)(document.body, 'el-popup-parent--hidden');
|
||||
}
|
||||
}
|
||||
|
||||
if (getComputedStyle(dom).position === 'static') {
|
||||
dom.style.position = 'absolute';
|
||||
}
|
||||
|
||||
dom.style.zIndex = _popupManager2.default.nextZIndex();
|
||||
this.opened = true;
|
||||
|
||||
this.onOpen && this.onOpen();
|
||||
|
||||
this.doAfterOpen();
|
||||
},
|
||||
doAfterOpen: function doAfterOpen() {
|
||||
this._opening = false;
|
||||
},
|
||||
close: function close() {
|
||||
var _this3 = this;
|
||||
|
||||
if (this.willClose && !this.willClose()) return;
|
||||
|
||||
if (this._openTimer !== null) {
|
||||
clearTimeout(this._openTimer);
|
||||
this._openTimer = null;
|
||||
}
|
||||
clearTimeout(this._closeTimer);
|
||||
|
||||
var closeDelay = Number(this.closeDelay);
|
||||
|
||||
if (closeDelay > 0) {
|
||||
this._closeTimer = setTimeout(function () {
|
||||
_this3._closeTimer = null;
|
||||
_this3.doClose();
|
||||
}, closeDelay);
|
||||
} else {
|
||||
this.doClose();
|
||||
}
|
||||
},
|
||||
doClose: function doClose() {
|
||||
this._closing = true;
|
||||
|
||||
this.onClose && this.onClose();
|
||||
|
||||
if (this.lockScroll) {
|
||||
setTimeout(this.restoreBodyStyle, 200);
|
||||
}
|
||||
|
||||
this.opened = false;
|
||||
|
||||
this.doAfterClose();
|
||||
},
|
||||
doAfterClose: function doAfterClose() {
|
||||
_popupManager2.default.closeModal(this._popupId);
|
||||
this._closing = false;
|
||||
},
|
||||
restoreBodyStyle: function restoreBodyStyle() {
|
||||
if (this.modal && this.withoutHiddenClass) {
|
||||
document.body.style.paddingRight = this.bodyPaddingRight;
|
||||
(0, _dom.removeClass)(document.body, 'el-popup-parent--hidden');
|
||||
}
|
||||
this.withoutHiddenClass = true;
|
||||
}
|
||||
}
|
||||
};
|
||||
exports.PopupManager = _popupManager2.default;
|
||||
205
public/static/libs/element-ui/lib/utils/popup/popup-manager.js
Normal file
205
public/static/libs/element-ui/lib/utils/popup/popup-manager.js
Normal file
@@ -0,0 +1,205 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
|
||||
var _vue = require('vue');
|
||||
|
||||
var _vue2 = _interopRequireDefault(_vue);
|
||||
|
||||
var _dom = require('element-ui/lib/utils/dom');
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var hasModal = false;
|
||||
var hasInitZIndex = false;
|
||||
var zIndex = void 0;
|
||||
|
||||
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 = {
|
||||
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.tabIndex = 0;
|
||||
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);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
Object.defineProperty(PopupManager, 'zIndex', {
|
||||
configurable: true,
|
||||
get: function get() {
|
||||
if (!hasInitZIndex) {
|
||||
zIndex = zIndex || (_vue2.default.prototype.$ELEMENT || {}).zIndex || 2000;
|
||||
hasInitZIndex = true;
|
||||
}
|
||||
return zIndex;
|
||||
},
|
||||
set: function set(value) {
|
||||
zIndex = value;
|
||||
}
|
||||
});
|
||||
|
||||
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);
|
||||
|
||||
return instance;
|
||||
}
|
||||
};
|
||||
|
||||
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();
|
||||
|
||||
if (topPopup && topPopup.closeOnPressEscape) {
|
||||
topPopup.handleClose ? topPopup.handleClose() : topPopup.handleAction ? topPopup.handleAction('cancel') : topPopup.close();
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
exports.default = PopupManager;
|
||||
59
public/static/libs/element-ui/lib/utils/resize-event.js
Normal file
59
public/static/libs/element-ui/lib/utils/resize-event.js
Normal file
@@ -0,0 +1,59 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
exports.removeResizeListener = exports.addResizeListener = undefined;
|
||||
|
||||
var _resizeObserverPolyfill = require('resize-observer-polyfill');
|
||||
|
||||
var _resizeObserverPolyfill2 = _interopRequireDefault(_resizeObserverPolyfill);
|
||||
|
||||
var _throttleDebounce = require('throttle-debounce');
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var isServer = typeof window === 'undefined';
|
||||
|
||||
/* istanbul ignore next */
|
||||
var resizeHandler = function resizeHandler(entries) {
|
||||
for (var _iterator = entries, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
|
||||
var _ref;
|
||||
|
||||
if (_isArray) {
|
||||
if (_i >= _iterator.length) break;
|
||||
_ref = _iterator[_i++];
|
||||
} else {
|
||||
_i = _iterator.next();
|
||||
if (_i.done) break;
|
||||
_ref = _i.value;
|
||||
}
|
||||
|
||||
var entry = _ref;
|
||||
|
||||
var listeners = entry.target.__resizeListeners__ || [];
|
||||
if (listeners.length) {
|
||||
listeners.forEach(function (fn) {
|
||||
fn();
|
||||
});
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
/* istanbul ignore next */
|
||||
var addResizeListener = exports.addResizeListener = function addResizeListener(element, fn) {
|
||||
if (isServer) return;
|
||||
if (!element.__resizeListeners__) {
|
||||
element.__resizeListeners__ = [];
|
||||
element.__ro__ = new _resizeObserverPolyfill2.default((0, _throttleDebounce.debounce)(16, resizeHandler));
|
||||
element.__ro__.observe(element);
|
||||
}
|
||||
element.__resizeListeners__.push(fn);
|
||||
};
|
||||
|
||||
/* istanbul ignore next */
|
||||
var removeResizeListener = exports.removeResizeListener = function removeResizeListener(element, fn) {
|
||||
if (!element || !element.__resizeListeners__) return;
|
||||
element.__resizeListeners__.splice(element.__resizeListeners__.indexOf(fn), 1);
|
||||
if (!element.__resizeListeners__.length) {
|
||||
element.__ro__.disconnect();
|
||||
}
|
||||
};
|
||||
38
public/static/libs/element-ui/lib/utils/scroll-into-view.js
Normal file
38
public/static/libs/element-ui/lib/utils/scroll-into-view.js
Normal file
@@ -0,0 +1,38 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
exports.default = scrollIntoView;
|
||||
|
||||
var _vue = require('vue');
|
||||
|
||||
var _vue2 = _interopRequireDefault(_vue);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
function scrollIntoView(container, selected) {
|
||||
if (_vue2.default.prototype.$isServer) return;
|
||||
|
||||
if (!selected) {
|
||||
container.scrollTop = 0;
|
||||
return;
|
||||
}
|
||||
|
||||
var offsetParents = [];
|
||||
var pointer = selected.offsetParent;
|
||||
while (pointer && container !== pointer && container.contains(pointer)) {
|
||||
offsetParents.push(pointer);
|
||||
pointer = pointer.offsetParent;
|
||||
}
|
||||
var top = selected.offsetTop + offsetParents.reduce(function (prev, curr) {
|
||||
return prev + curr.offsetTop;
|
||||
}, 0);
|
||||
var bottom = top + selected.offsetHeight;
|
||||
var viewRectTop = container.scrollTop;
|
||||
var viewRectBottom = viewRectTop + container.clientHeight;
|
||||
|
||||
if (top < viewRectTop) {
|
||||
container.scrollTop = top;
|
||||
} else if (bottom > viewRectBottom) {
|
||||
container.scrollTop = bottom - container.clientHeight;
|
||||
}
|
||||
}
|
||||
39
public/static/libs/element-ui/lib/utils/scrollbar-width.js
Normal file
39
public/static/libs/element-ui/lib/utils/scrollbar-width.js
Normal file
@@ -0,0 +1,39 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
|
||||
exports.default = function () {
|
||||
if (_vue2.default.prototype.$isServer) return 0;
|
||||
if (scrollBarWidth !== undefined) return scrollBarWidth;
|
||||
|
||||
var outer = document.createElement('div');
|
||||
outer.className = 'el-scrollbar__wrap';
|
||||
outer.style.visibility = 'hidden';
|
||||
outer.style.width = '100px';
|
||||
outer.style.position = 'absolute';
|
||||
outer.style.top = '-9999px';
|
||||
document.body.appendChild(outer);
|
||||
|
||||
var widthNoScroll = outer.offsetWidth;
|
||||
outer.style.overflow = 'scroll';
|
||||
|
||||
var inner = document.createElement('div');
|
||||
inner.style.width = '100%';
|
||||
outer.appendChild(inner);
|
||||
|
||||
var widthWithScroll = inner.offsetWidth;
|
||||
outer.parentNode.removeChild(outer);
|
||||
scrollBarWidth = widthNoScroll - widthWithScroll;
|
||||
|
||||
return scrollBarWidth;
|
||||
};
|
||||
|
||||
var _vue = require('vue');
|
||||
|
||||
var _vue2 = _interopRequireDefault(_vue);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var scrollBarWidth = void 0;
|
||||
|
||||
;
|
||||
12
public/static/libs/element-ui/lib/utils/shared.js
Normal file
12
public/static/libs/element-ui/lib/utils/shared.js
Normal file
@@ -0,0 +1,12 @@
|
||||
"use strict";
|
||||
|
||||
exports.__esModule = true;
|
||||
exports.isDef = isDef;
|
||||
exports.isKorean = isKorean;
|
||||
function isDef(val) {
|
||||
return val !== undefined && val !== null;
|
||||
}
|
||||
function isKorean(text) {
|
||||
var reg = /([(\uAC00-\uD7AF)|(\u3130-\u318F)])+/gi;
|
||||
return reg.test(text);
|
||||
}
|
||||
52
public/static/libs/element-ui/lib/utils/types.js
Normal file
52
public/static/libs/element-ui/lib/utils/types.js
Normal file
@@ -0,0 +1,52 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
exports.isDefined = exports.isUndefined = exports.isFunction = 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; };
|
||||
|
||||
exports.isString = isString;
|
||||
exports.isObject = isObject;
|
||||
exports.isHtmlElement = isHtmlElement;
|
||||
|
||||
var _vue = require('vue');
|
||||
|
||||
var _vue2 = _interopRequireDefault(_vue);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
function isString(obj) {
|
||||
return Object.prototype.toString.call(obj) === '[object String]';
|
||||
}
|
||||
|
||||
function isObject(obj) {
|
||||
return Object.prototype.toString.call(obj) === '[object Object]';
|
||||
}
|
||||
|
||||
function isHtmlElement(node) {
|
||||
return node && node.nodeType === Node.ELEMENT_NODE;
|
||||
}
|
||||
|
||||
/**
|
||||
* - Inspired:
|
||||
* https://github.com/jashkenas/underscore/blob/master/modules/isFunction.js
|
||||
*/
|
||||
var isFunction = function isFunction(functionToCheck) {
|
||||
var getType = {};
|
||||
return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
|
||||
};
|
||||
|
||||
if (typeof /./ !== 'function' && (typeof Int8Array === 'undefined' ? 'undefined' : _typeof(Int8Array)) !== 'object' && (_vue2.default.prototype.$isServer || typeof document.childNodes !== 'function')) {
|
||||
exports.isFunction = isFunction = function isFunction(obj) {
|
||||
return typeof obj === 'function' || false;
|
||||
};
|
||||
}
|
||||
|
||||
exports.isFunction = isFunction;
|
||||
var isUndefined = exports.isUndefined = function isUndefined(val) {
|
||||
return val === void 0;
|
||||
};
|
||||
|
||||
var isDefined = exports.isDefined = function isDefined(val) {
|
||||
return val !== undefined && val !== null;
|
||||
};
|
||||
272
public/static/libs/element-ui/lib/utils/util.js
Normal file
272
public/static/libs/element-ui/lib/utils/util.js
Normal file
@@ -0,0 +1,272 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
exports.isMac = exports.isEmpty = exports.isEqual = exports.arrayEquals = exports.looseEqual = exports.capitalize = exports.kebabCase = exports.autoprefixer = exports.isFirefox = exports.isEdge = exports.isIE = exports.coerceTruthyValueToArray = exports.arrayFind = exports.arrayFindIndex = exports.escapeRegexpString = exports.valueEquals = exports.generateId = exports.getValueByPath = 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; };
|
||||
|
||||
exports.noop = noop;
|
||||
exports.hasOwn = hasOwn;
|
||||
exports.toObject = toObject;
|
||||
exports.getPropByPath = getPropByPath;
|
||||
exports.rafThrottle = rafThrottle;
|
||||
exports.objToArray = objToArray;
|
||||
|
||||
var _vue = require('vue');
|
||||
|
||||
var _vue2 = _interopRequireDefault(_vue);
|
||||
|
||||
var _types = require('element-ui/lib/utils/types');
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var hasOwnProperty = Object.prototype.hasOwnProperty;
|
||||
|
||||
function noop() {};
|
||||
|
||||
function hasOwn(obj, key) {
|
||||
return hasOwnProperty.call(obj, key);
|
||||
};
|
||||
|
||||
function extend(to, _from) {
|
||||
for (var key in _from) {
|
||||
to[key] = _from[key];
|
||||
}
|
||||
return to;
|
||||
};
|
||||
|
||||
function toObject(arr) {
|
||||
var res = {};
|
||||
for (var i = 0; i < arr.length; i++) {
|
||||
if (arr[i]) {
|
||||
extend(res, arr[i]);
|
||||
}
|
||||
}
|
||||
return res;
|
||||
};
|
||||
|
||||
var getValueByPath = exports.getValueByPath = function getValueByPath(object, prop) {
|
||||
prop = prop || '';
|
||||
var paths = prop.split('.');
|
||||
var current = object;
|
||||
var result = null;
|
||||
for (var i = 0, j = paths.length; i < j; i++) {
|
||||
var path = paths[i];
|
||||
if (!current) break;
|
||||
|
||||
if (i === j - 1) {
|
||||
result = current[path];
|
||||
break;
|
||||
}
|
||||
current = current[path];
|
||||
}
|
||||
return result;
|
||||
};
|
||||
|
||||
function getPropByPath(obj, path, strict) {
|
||||
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) {
|
||||
if (!tempObj && !strict) break;
|
||||
var key = keyArr[i];
|
||||
if (key in tempObj) {
|
||||
tempObj = tempObj[key];
|
||||
} else {
|
||||
if (strict) {
|
||||
throw new Error('please transfer a valid prop path to form item!');
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
return {
|
||||
o: tempObj,
|
||||
k: keyArr[i],
|
||||
v: tempObj ? tempObj[keyArr[i]] : null
|
||||
};
|
||||
};
|
||||
|
||||
var generateId = exports.generateId = function generateId() {
|
||||
return Math.floor(Math.random() * 10000);
|
||||
};
|
||||
|
||||
var valueEquals = exports.valueEquals = function valueEquals(a, b) {
|
||||
// see: https://stackoverflow.com/questions/3115982/how-to-check-if-two-arrays-are-equal-with-javascript
|
||||
if (a === b) return true;
|
||||
if (!(a instanceof Array)) return false;
|
||||
if (!(b instanceof Array)) return false;
|
||||
if (a.length !== b.length) return false;
|
||||
for (var i = 0; i !== a.length; ++i) {
|
||||
if (a[i] !== b[i]) return false;
|
||||
}
|
||||
return true;
|
||||
};
|
||||
|
||||
var escapeRegexpString = exports.escapeRegexpString = function escapeRegexpString() {
|
||||
var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
|
||||
return String(value).replace(/[|\\{}()[\]^$+*?.]/g, '\\$&');
|
||||
};
|
||||
|
||||
// TODO: use native Array.find, Array.findIndex when IE support is dropped
|
||||
var arrayFindIndex = exports.arrayFindIndex = function arrayFindIndex(arr, pred) {
|
||||
for (var i = 0; i !== arr.length; ++i) {
|
||||
if (pred(arr[i])) {
|
||||
return i;
|
||||
}
|
||||
}
|
||||
return -1;
|
||||
};
|
||||
|
||||
var arrayFind = exports.arrayFind = function arrayFind(arr, pred) {
|
||||
var idx = arrayFindIndex(arr, pred);
|
||||
return idx !== -1 ? arr[idx] : undefined;
|
||||
};
|
||||
|
||||
// coerce truthy value to array
|
||||
var coerceTruthyValueToArray = exports.coerceTruthyValueToArray = function coerceTruthyValueToArray(val) {
|
||||
if (Array.isArray(val)) {
|
||||
return val;
|
||||
} else if (val) {
|
||||
return [val];
|
||||
} else {
|
||||
return [];
|
||||
}
|
||||
};
|
||||
|
||||
var isIE = exports.isIE = function isIE() {
|
||||
return !_vue2.default.prototype.$isServer && !isNaN(Number(document.documentMode));
|
||||
};
|
||||
|
||||
var isEdge = exports.isEdge = function isEdge() {
|
||||
return !_vue2.default.prototype.$isServer && navigator.userAgent.indexOf('Edge') > -1;
|
||||
};
|
||||
|
||||
var isFirefox = exports.isFirefox = function isFirefox() {
|
||||
return !_vue2.default.prototype.$isServer && !!window.navigator.userAgent.match(/firefox/i);
|
||||
};
|
||||
|
||||
var autoprefixer = exports.autoprefixer = function autoprefixer(style) {
|
||||
if ((typeof style === 'undefined' ? 'undefined' : _typeof(style)) !== 'object') return style;
|
||||
var rules = ['transform', 'transition', 'animation'];
|
||||
var prefixes = ['ms-', 'webkit-'];
|
||||
rules.forEach(function (rule) {
|
||||
var value = style[rule];
|
||||
if (rule && value) {
|
||||
prefixes.forEach(function (prefix) {
|
||||
style[prefix + rule] = value;
|
||||
});
|
||||
}
|
||||
});
|
||||
return style;
|
||||
};
|
||||
|
||||
var kebabCase = exports.kebabCase = function kebabCase(str) {
|
||||
var hyphenateRE = /([^-])([A-Z])/g;
|
||||
return str.replace(hyphenateRE, '$1-$2').replace(hyphenateRE, '$1-$2').toLowerCase();
|
||||
};
|
||||
|
||||
var capitalize = exports.capitalize = function capitalize(str) {
|
||||
if (!(0, _types.isString)(str)) return str;
|
||||
return str.charAt(0).toUpperCase() + str.slice(1);
|
||||
};
|
||||
|
||||
var looseEqual = exports.looseEqual = function looseEqual(a, b) {
|
||||
var isObjectA = (0, _types.isObject)(a);
|
||||
var isObjectB = (0, _types.isObject)(b);
|
||||
if (isObjectA && isObjectB) {
|
||||
return JSON.stringify(a) === JSON.stringify(b);
|
||||
} else if (!isObjectA && !isObjectB) {
|
||||
return String(a) === String(b);
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
};
|
||||
|
||||
var arrayEquals = exports.arrayEquals = function arrayEquals(arrayA, arrayB) {
|
||||
arrayA = arrayA || [];
|
||||
arrayB = arrayB || [];
|
||||
|
||||
if (arrayA.length !== arrayB.length) {
|
||||
return false;
|
||||
}
|
||||
|
||||
for (var i = 0; i < arrayA.length; i++) {
|
||||
if (!looseEqual(arrayA[i], arrayB[i])) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
};
|
||||
|
||||
var isEqual = exports.isEqual = function isEqual(value1, value2) {
|
||||
if (Array.isArray(value1) && Array.isArray(value2)) {
|
||||
return arrayEquals(value1, value2);
|
||||
}
|
||||
return looseEqual(value1, value2);
|
||||
};
|
||||
|
||||
var isEmpty = exports.isEmpty = function isEmpty(val) {
|
||||
// null or undefined
|
||||
if (val == null) return true;
|
||||
|
||||
if (typeof val === 'boolean') return false;
|
||||
|
||||
if (typeof val === 'number') return !val;
|
||||
|
||||
if (val instanceof Error) return val.message === '';
|
||||
|
||||
switch (Object.prototype.toString.call(val)) {
|
||||
// String or Array
|
||||
case '[object String]':
|
||||
case '[object Array]':
|
||||
return !val.length;
|
||||
|
||||
// Map or Set or File
|
||||
case '[object File]':
|
||||
case '[object Map]':
|
||||
case '[object Set]':
|
||||
{
|
||||
return !val.size;
|
||||
}
|
||||
// Plain Object
|
||||
case '[object Object]':
|
||||
{
|
||||
return !Object.keys(val).length;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
};
|
||||
|
||||
function rafThrottle(fn) {
|
||||
var locked = false;
|
||||
return function () {
|
||||
var _this = this;
|
||||
|
||||
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
|
||||
args[_key] = arguments[_key];
|
||||
}
|
||||
|
||||
if (locked) return;
|
||||
locked = true;
|
||||
window.requestAnimationFrame(function (_) {
|
||||
fn.apply(_this, args);
|
||||
locked = false;
|
||||
});
|
||||
};
|
||||
}
|
||||
|
||||
function objToArray(obj) {
|
||||
if (Array.isArray(obj)) {
|
||||
return obj;
|
||||
}
|
||||
return isEmpty(obj) ? [] : [obj];
|
||||
}
|
||||
|
||||
var isMac = exports.isMac = function isMac() {
|
||||
return !_vue2.default.prototype.$isServer && /macintosh|mac os x/i.test(navigator.userAgent);
|
||||
};
|
||||
13
public/static/libs/element-ui/lib/utils/vdom.js
Normal file
13
public/static/libs/element-ui/lib/utils/vdom.js
Normal file
@@ -0,0 +1,13 @@
|
||||
'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.isVNode = isVNode;
|
||||
|
||||
var _util = require('element-ui/lib/utils/util');
|
||||
|
||||
function isVNode(node) {
|
||||
return node !== null && (typeof node === 'undefined' ? 'undefined' : _typeof(node)) === 'object' && (0, _util.hasOwn)(node, 'componentOptions');
|
||||
};
|
||||
202
public/static/libs/element-ui/lib/utils/vue-popper.js
Normal file
202
public/static/libs/element-ui/lib/utils/vue-popper.js
Normal file
@@ -0,0 +1,202 @@
|
||||
'use strict';
|
||||
|
||||
exports.__esModule = true;
|
||||
|
||||
var _vue = require('vue');
|
||||
|
||||
var _vue2 = _interopRequireDefault(_vue);
|
||||
|
||||
var _popup = require('element-ui/lib/utils/popup');
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
var PopperJS = _vue2.default.prototype.$isServer ? function () {} : require('./popper');
|
||||
var stop = function stop(e) {
|
||||
return e.stopPropagation();
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {HTMLElement} [reference=$refs.reference] - The reference element used to position the popper.
|
||||
* @param {HTMLElement} [popper=$refs.popper] - The HTML element used as popper, or a configuration used to generate the popper.
|
||||
* @param {String} [placement=button] - Placement of the popper accepted values: top(-start, -end), right(-start, -end), bottom(-start, -end), left(-start, -end)
|
||||
* @param {Number} [offset=0] - Amount of pixels the popper will be shifted (can be negative).
|
||||
* @param {Boolean} [visible=false] Visibility of the popup element.
|
||||
* @param {Boolean} [visible-arrow=false] Visibility of the arrow, no style.
|
||||
*/
|
||||
exports.default = {
|
||||
props: {
|
||||
transformOrigin: {
|
||||
type: [Boolean, String],
|
||||
default: true
|
||||
},
|
||||
placement: {
|
||||
type: String,
|
||||
default: 'bottom'
|
||||
},
|
||||
boundariesPadding: {
|
||||
type: Number,
|
||||
default: 5
|
||||
},
|
||||
reference: {},
|
||||
popper: {},
|
||||
offset: {
|
||||
default: 0
|
||||
},
|
||||
value: Boolean,
|
||||
visibleArrow: Boolean,
|
||||
arrowOffset: {
|
||||
type: Number,
|
||||
default: 35
|
||||
},
|
||||
appendToBody: {
|
||||
type: Boolean,
|
||||
default: true
|
||||
},
|
||||
popperOptions: {
|
||||
type: Object,
|
||||
default: function _default() {
|
||||
return {
|
||||
gpuAcceleration: false
|
||||
};
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
data: function data() {
|
||||
return {
|
||||
showPopper: false,
|
||||
currentPlacement: ''
|
||||
};
|
||||
},
|
||||
|
||||
|
||||
watch: {
|
||||
value: {
|
||||
immediate: true,
|
||||
handler: function handler(val) {
|
||||
this.showPopper = val;
|
||||
this.$emit('input', val);
|
||||
}
|
||||
},
|
||||
|
||||
showPopper: function showPopper(val) {
|
||||
if (this.disabled) return;
|
||||
val ? this.updatePopper() : this.destroyPopper();
|
||||
this.$emit('input', val);
|
||||
}
|
||||
},
|
||||
|
||||
methods: {
|
||||
createPopper: function createPopper() {
|
||||
var _this = this;
|
||||
|
||||
if (this.$isServer) return;
|
||||
this.currentPlacement = this.currentPlacement || this.placement;
|
||||
if (!/^(top|bottom|left|right)(-start|-end)?$/g.test(this.currentPlacement)) {
|
||||
return;
|
||||
}
|
||||
|
||||
var options = this.popperOptions;
|
||||
var popper = this.popperElm = this.popperElm || this.popper || this.$refs.popper;
|
||||
var reference = this.referenceElm = this.referenceElm || this.reference || this.$refs.reference;
|
||||
|
||||
if (!reference && this.$slots.reference && this.$slots.reference[0]) {
|
||||
reference = this.referenceElm = this.$slots.reference[0].elm;
|
||||
}
|
||||
|
||||
if (!popper || !reference) return;
|
||||
if (this.visibleArrow) this.appendArrow(popper);
|
||||
if (this.appendToBody) document.body.appendChild(this.popperElm);
|
||||
if (this.popperJS && this.popperJS.destroy) {
|
||||
this.popperJS.destroy();
|
||||
}
|
||||
|
||||
options.placement = this.currentPlacement;
|
||||
options.offset = this.offset;
|
||||
options.arrowOffset = this.arrowOffset;
|
||||
this.popperJS = new PopperJS(reference, popper, options);
|
||||
this.popperJS.onCreate(function (_) {
|
||||
_this.$emit('created', _this);
|
||||
_this.resetTransformOrigin();
|
||||
_this.$nextTick(_this.updatePopper);
|
||||
});
|
||||
if (typeof options.onUpdate === 'function') {
|
||||
this.popperJS.onUpdate(options.onUpdate);
|
||||
}
|
||||
this.popperJS._popper.style.zIndex = _popup.PopupManager.nextZIndex();
|
||||
this.popperElm.addEventListener('click', stop);
|
||||
},
|
||||
updatePopper: function updatePopper() {
|
||||
var popperJS = this.popperJS;
|
||||
if (popperJS) {
|
||||
popperJS.update();
|
||||
if (popperJS._popper) {
|
||||
popperJS._popper.style.zIndex = _popup.PopupManager.nextZIndex();
|
||||
}
|
||||
} else {
|
||||
this.createPopper();
|
||||
}
|
||||
},
|
||||
doDestroy: function doDestroy(forceDestroy) {
|
||||
/* istanbul ignore if */
|
||||
if (!this.popperJS || this.showPopper && !forceDestroy) return;
|
||||
this.popperJS.destroy();
|
||||
this.popperJS = null;
|
||||
},
|
||||
destroyPopper: function destroyPopper() {
|
||||
if (this.popperJS) {
|
||||
this.resetTransformOrigin();
|
||||
}
|
||||
},
|
||||
resetTransformOrigin: function resetTransformOrigin() {
|
||||
if (!this.transformOrigin) return;
|
||||
var placementMap = {
|
||||
top: 'bottom',
|
||||
bottom: 'top',
|
||||
left: 'right',
|
||||
right: 'left'
|
||||
};
|
||||
var placement = this.popperJS._popper.getAttribute('x-placement').split('-')[0];
|
||||
var origin = placementMap[placement];
|
||||
this.popperJS._popper.style.transformOrigin = typeof this.transformOrigin === 'string' ? this.transformOrigin : ['top', 'bottom'].indexOf(placement) > -1 ? 'center ' + origin : origin + ' center';
|
||||
},
|
||||
appendArrow: function appendArrow(element) {
|
||||
var hash = void 0;
|
||||
if (this.appended) {
|
||||
return;
|
||||
}
|
||||
|
||||
this.appended = true;
|
||||
|
||||
for (var item in element.attributes) {
|
||||
if (/^_v-/.test(element.attributes[item].name)) {
|
||||
hash = element.attributes[item].name;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
var arrow = document.createElement('div');
|
||||
|
||||
if (hash) {
|
||||
arrow.setAttribute(hash, '');
|
||||
}
|
||||
arrow.setAttribute('x-arrow', '');
|
||||
arrow.className = 'popper__arrow';
|
||||
element.appendChild(arrow);
|
||||
}
|
||||
},
|
||||
|
||||
beforeDestroy: function beforeDestroy() {
|
||||
this.doDestroy(true);
|
||||
if (this.popperElm && this.popperElm.parentNode === document.body) {
|
||||
this.popperElm.removeEventListener('click', stop);
|
||||
document.body.removeChild(this.popperElm);
|
||||
}
|
||||
},
|
||||
|
||||
|
||||
// call destroy in keep-alive mode
|
||||
deactivated: function deactivated() {
|
||||
this.$options.beforeDestroy[0].call(this);
|
||||
}
|
||||
};
|
||||
Reference in New Issue
Block a user